Pereiti prie turinio

Rekomenduojami pranešimai

Apsauga nuo SQL "injekcijų":

http://php.net/manua...-statements.php

http://php.net/manua...-statements.php

 

Apsauga nuo XSS tipo atakų:

http://php.net/manua...tmlentities.php

http://php.net/manua...pecialchars.php

 

... arba jei nori praleisti saugų HTML kodą:

http://htmlpurifier.org/

Redagavo dragelis
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Viskas yra čia. http://www.phptherightway.com/

 

Duomenų bazei MySQLi ar PDO, XSS – htmlspecialchars turbūt tiktų.

 

O šiaip neįsivaizduok „apsaugų“ kaip kažkokio atskiro dalyko. Turi pats domėtis ne tik „kaip apsaugoti“, bet ir dėl ko taip yra, kad suprastum kaip neatsiejamą dalį :) Turbūt geriausias šaltinis tam – OWASP Top 10 https://www.owasp.org/index.php/Category:OWASP_Top_Ten_Project . Apsisaugok nuo Top 10 ir jau bus neblogai :)

 

Jau kurį laiką naudoju šį filtrą:

function clean($str)
{
$cleaned = strip_tags($str);
$cleaned = htmlspecialchars(mysql_real_escape_string($cleaned));
$cleaned = str_replace("%20", "", $cleaned);
return $cleaned;
}

 

Nereikėtų tokio filtro naudoti viskam. Jei visgi naudojamas mysql escapinimas o ne normalūs parametrų bindinimai, tai turėtų būti atliekama insertinimo/filtravimo metu, o štai htmlspecialchars – atvaizdavimo metu (strip_tags – kita tema, tą galima ir insertinant, jei to tikrai tikrai reikia).

Nuoroda į pranešimą
Dalintis kituose puslapiuose

O kaip dėl šito mysql_real_escape_string() ?

ext/mysql (mysql_* funkcijos) apskritai yra ilgalaikiame deprecatinimo procese – kol kas vis dar yra PHP'e, bet kažkada dings. Beje, int/float reikia ne escapinti, o castinti į atitinkamą tipą – apostrofų juose gali ir nebūti, o injekciją padarysi ir be apostrofų...

 

Primygtinai siūlau naudoti PDO ar MySQLi. Prepared statements naudinga visais aspektais: ir greičiau, ir saugiau (pabrėžiu – tik normaliai bindinant parametrus, kitaip jokios magijos be tavo žinios neatlieka). Negi taip bijai patobulėti? Kartu ir OOP pasimokysi, ko, įtariu, prieiti nespėjai, jei kyla tokie klausimai, kaip „kaip apsisaugoti, gal real_escape“.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

ext/mysql (mysql_* funkcijos) apskritai yra ilgalaikiame deprecatinimo procese – kol kas vis dar yra PHP'e, bet kažkada dings. Beje, int/float reikia ne escapinti, o castinti į atitinkamą tipą – apostrofų juose gali ir nebūti, o injekciją padarysi ir be apostrofų...

 

Primygtinai siūlau naudoti PDO ar MySQLi. Prepared statements naudinga visais aspektais: ir greičiau, ir saugiau (pabrėžiu – tik normaliai bindinant parametrus, kitaip jokios magijos be tavo žinios neatlieka). Negi taip bijai patobulėti? Kartu ir OOP pasimokysi, ko, įtariu, prieiti nespėjai, jei kyla tokie klausimai, kaip „kaip apsisaugoti, gal real_escape“.

Gerai mėginsime su PDO

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ą...