• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

SQL injection, hashowanie haseł

Object Storage Arubacloud
0 głosów
554 wizyt
pytanie zadane 30 listopada 2018 w PHP przez marcolo Obywatel (1,530 p.)

Właściwie to mam dwa pytania, pierwsze to jak radzicie sobie z "SQL injection".

Do tej pory robiłem coś takiego:

$_POST['login'] = strip_tags($_POST['login']);
	
$_POST['login'] = mysqli_real_escape_string($con, $_POST['login']);

Czy to wystarczy, czy jest lepszy sposób?

 

Drugie pytanie to w jaki sposób hashujecie hasła?

Ja używam:

$pass = hash("sha512", $salt.$pw);

a zastanawiam się nad używaniem

password_hash($hasło, PASSWORD_BCRYPT);

 

1 odpowiedź

+1 głos
odpowiedź 30 listopada 2018 przez Arkadiusz Waluk Ekspert (287,950 p.)
wybrane 30 listopada 2018 przez marcolo
 
Najlepsza
Jeśli chodzi o SQL injection to należy bindować wartości, wtedy zapytanie i wartości są do bazy wysyłane osobno, więc nie ma szansy na żadne wstrzykiwanie.

Do haseł należy używać password_hash() i password_verify(), algorytmem może być bcrypt choć od PHP 7.2 jest dostępny też Argon2.
komentarz 30 listopada 2018 przez marcolo Obywatel (1,530 p.)
Przy bindowaniu mamy szybkie bindowanie, gdzie zmienne podajemy w metodzie "execute()" lub możemy używać bindValue()/bindParam.

Jak przeczytałem sobie o tym, to jakoś bardziej spodobała mi się wersja z execute(), ale autor nie pisał o różnicach, jest ona w jakiś sposób gorsza od bindValue()/bindParam?
komentarz 30 listopada 2018 przez Arkadiusz Waluk Ekspert (287,950 p.)
Mówimy o mysqli? Bo z niego korzystasz w pokazanym fragmencie, a wydaje mi się, że w mysqli dostępne jest tylko bind_param() i execute() nieprzyjmujące parametrów. bindValue(), bindParam() i execute() z możliwością podania parametrów jest w PDO.
1
komentarz 30 listopada 2018 przez marcolo Obywatel (1,530 p.)
Ok, dzięki, tego nie doczytałem się, tak mysqli, choć cały czas myślę o pójściu w stronę PDO, a ostatecznie i tak kończę z mysqli :D

Podobne pytania

0 głosów
1 odpowiedź 708 wizyt
+7 głosów
5 odpowiedzi 310 wizyt
0 głosów
3 odpowiedzi 1,080 wizyt
pytanie zadane 6 czerwca 2019 w PHP przez DODO Bywalec (2,950 p.)

92,620 zapytań

141,471 odpowiedzi

319,794 komentarzy

62,002 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...