Aktywne Wpisy
zbyszko17 +312
Zapraszam do pisania swoich propozycji "na chlopski rozum" na temat zwalczenia powodzi na śląsku. Zaczne od mojej, skoro na Wiśle jest rekordowy niski poziom wody to może przekierujemy rzekę tak aby plynela do Wisły? #powodz
aegypius +392
Czy ten naród już totalnie zdziczał i pozbył się jakichkolwiek przejawów człowieczeństwa i rozumu?
Pamiętam 1997 i powódź (jako obserwator, nie uczestnik):
- ludzie brali sprawy w swoje ręce, bo rząd był jak dziecko we mgle
- wędkarze przyjeźdżali ze swoimi łódkami
- właściciele składów budowlanych dawali piasek
Pamiętam 1997 i powódź (jako obserwator, nie uczestnik):
- ludzie brali sprawy w swoje ręce, bo rząd był jak dziecko we mgle
- wędkarze przyjeźdżali ze swoimi łódkami
- właściciele składów budowlanych dawali piasek
Dlaczego więc nie warto używać
Random
w #java ? #od0dopentesteraKażdy szanujący się serwis posiada funkcjonalność resetowania hasła.
Użytkownik podaje na stronie swój adres email powiązany z kontem.
W tym momencie serwer sprawdza czy taki użytkownik istnieje w bazie danych.
Jeśli tak - generuje unikalny ciąg, który jest następnie zapisywany i wysyłany w emailu.
Następnie użytkownik odczytuje email i klika w zawarty tam odnośnik z zapisanym unikalnym kluczem.
Serwer sprawdza czy unikalny ciąg znajduje się w bazie danych - i jeśli wszystko się zgadza pozwala na zmianę hasła.
Nasz kod generujący unikalny token wygląda tak:
static Random r = new Random();
}static String getToken() {
return Integer.toString(r.nextInt());
Gdzie zatem znajduje się dzisiejszy błąd?
Klasa
Random
jest generatorem liczb pseudolosowych.Oznacza to że na podstawie niewielkiej ilości informacji - tak zwanego ziarna generuje ona deterministycznie kolejne liczby pseudolosowe.
Ziarno to może być zdefiniowane przez użytkownika - lub też jak w naszym przypadku ustawione automatycznie przez Jave.
Wystarczy więc odgadnąć jakie ziarno zostało użyte aby móc generować kolejne liczby tokena na własnym komputerze.
Do przywrócenia ziarna użyjemy kodu dostępnego na forum stackoverflow.
Do swojego działania potrzebuje on 2 kolejnych liczb wygenerowanych przez daną instancje klasy Random.
Jak je otrzymać? W przypadku funkcjonalności przypominania hasła jest to bardzo proste.
Wystarczy bowiem dwa razy poprosić o reset konta, do którego posiadamy uprawnienia a za trzecim razem spróbować zresetować konto admina.
Następnie odczytujemy 2 pierwsze wartości z maila, do którego dostęp posiadamy i przekazujemy je do funkcji.
Właśnie wygenerowaliśmy unikalny identyfikator, którego można by było użyć do resetowania hasła administratora.
Oczywiście zakładam tutaj, że mamy szczęście i pomiędzy naszymi próbami nikt inny nie wykonał tej samej akcji.
Jak zatem zabezpieczyć się przed tym problemem?
Zawsze używać klasy
SecureRandom
.Identyczny problem istnieje również z klasą
RandomStringUtils
.Tam jednak odzyskanie ziarna trwa nieco dłużej.
#security #bezpieczenstwo #programowanie #informatyka #it #nauka #technologia #ciekawostki
Jak stworzyć idealny generator znaków losowych?
Posadzić żółtodzioba przed VIMem i kazać mu z niego wyjść.
Taki sam efekt uzyskali by nagrywając byle co, np. ulicę na zewnątrz.
Ale już by nie było takiego och, ah.
@ElegancikzPolski: No nie do końca, koło 3-4 w nocy zdjęcia byłyby nieruchome. Wiadomo, że szum by się zmieniał, ale dopóki tego doświadczalnie nie zbadać nie wiadomo czy dostatecznie losowo przy dobrej kamerze i podświetleniu IR.
a co do wykorzystywania dźwięku z ulicy/nagrań twarzy nie wiem czy by nie musieli się poddać jakiemuś odpowiednikowi RODO, co innego przechowywanie CCTV a co innego wykorzystywanie tego do generowania liczb
Z tego co wiem, dobrym generatorem losowym jest licznik Geigera rejestrujący rozpad promieniotwórczy, który zachodzi losowo.
@ElegancikzPolski: no tak, ale nie do końca - lampy lava czy inne fizyczne źródła nie są podatne na modyfikację (są nieprzewidywalne i niesterowalne), na widok za oknem osoby trzecie mają wpływ - a to wystarczy żeby zmniejszyć siłę szyfru (odjąć kilka bitów z efektywnej długości szyfru)