Pereiti prie turinio

DoS ataka (hash table collisions)


Rekomenduojami pranešimai

Sugeneravau 65k+ raktus (2 pakelta 16 laipsniu) ir nusiunčiau į savo serverį kaip "post" užklausą. Serveryje startavo php procesas naudojantis 99% CPU ir truko apie 25 sekundes, negerai :/

 

Pristatymas:

http://www.youtube.com/watch?v=R2Cq3CLI6H8

 

Daugiau informacijos: http://www.cs.rice.edu/~scrosby/hash/CrosbyWallach_UsenixSec2003/

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Iš tikrųjų ir aš prieš pora dienų pamačiau šią naujieną, tik šiandien peržiūrėjau video. Tik nesupratau - ar visa tai apkrauna CPU net jei nesikreipi į tuos elementus? Jei taip, tai gal todėl, kad lėčiau būna ir juos įterpti, kai tenka pereiti per visą linked list'ą tam reikalui? Ar gerai mąstau? :unsure:

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Tik nesupratau - ar visa tai apkrauna CPU net jei nesikreipi į tuos elementus?

 

Taip, PHP atveju užtenka tuščio failo (0 baitų), tiesiog reikia kad PHP interpretatorius įsijungtu. Net nesikreipiant į elementus startavimo metu PHP sukuria globalius objektus ($_POST, $_GET, ir t.t.) ir šiuo atveju dar prieš pradedant vykdyti skripto instrukcijas į $_POST rašomi visi kenksmingi raktai.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Taip, PHP atveju užtenka tuščio failo (0 baitų), tiesiog reikia kad PHP interpretatorius įsijungtu. Net nesikreipiant į elementus startavimo metu PHP sukuria globalius objektus ($_POST, $_GET, ir t.t.) ir šiuo atveju dar prieš pradedant vykdyti skripto instrukcijas į $_POST rašomi visi kenksmingi raktai.

Ne visai tą turėjau omeny :) Aš labiau apie veiksmą tam hashtable lygy. Ar CPU kankinamas todėl, kad įterpinėjant raktus su vienodais hash'ais prieš įterpiant reikia praeiti dar ir prieš visus ankstesnius elementus su tuo hashu? :)

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Ne visai tą turėjau omeny :) Aš labiau apie veiksmą tam hashtable lygy. Ar CPU kankinamas todėl, kad įterpinėjant raktus su vienodais hash'ais prieš įterpiant reikia praeiti dar ir prieš visus ankstesnius elementus su tuo hashu? :)

 

Taip, rašant naują raktą su tuo pačiu hashu reikia pereiti per visus tam hashe esancius elementus (pvz. su strcmp()) ir patikrinti ar toks raktas jau yra. Video prezentacijoj apie tai šneka apie 6:00.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Jau yra fixas šiam dalykui, tik reiks palaukti kol bus išleista PHP 5.3.9 versija.

PHP 5.3.9 which will add a max_input_vars ini setting which defaults to 1000.

Iš tikrųjų būtų labai gerai sulaukti kažko tokio iš web serverių (Apache, lighttpd, nginx) pusės. Greitai užmetus akį, pavyzdžiui, nginx turi tik bendrą request'o body ilgio limitą, bet toks nustatymas ne visada gali tikti.

 

EDIT: ir netgi mano minėta nginx direktyva netinka, nes tada kartu ribojamas ir failo dydis. Taigi, kol kas teks saugotis ne iš serverio, bet aplikacijos pusės. Sprendimas Python (WSGI) (tik GET :().

Redagavo Silke
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...