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

Sanityzacja PHP odc. 3

Object Storage Arubacloud
0 głosów
2,521 wizyt
pytanie zadane 26 listopada 2016 w PHP przez gipsy222 Nowicjusz (120 p.)
edycja 27 listopada 2016 przez gipsy222

Dlaczego w w odc.3 PHP:  https://youtu.be/fMJw90n8M60?t=2667  walidacje poprzedzono sanityzacją? Jaki jest sens robienia sanityzacji skoro walidacja sprawdza poprawność składniową mail'a. Proszę o podanie kontrprzykładu.

z góry thx

Tu dodatek do pytania z manual'a PHP + to co dodał autor podczas omawiania poprawności mail'a - możliwe ze te wytyczne odpowiadają składni opisanej w RFC 822.

2 odpowiedzi

0 głosów
odpowiedź 27 listopada 2016 przez Assasz Nałogowiec (30,460 p.)
Walidacja jedynie odpowiada za poprawne sformatowanie emaila, a nie usunie z niego niedozwolonych znaków. Za to odpowiada sanityzacja.

Np. jeśli użyjesz samej walidacji email e(x)ample/@gmail.com byłby ok. Natomiast z samą sanityzacją example@gmail byłby ok. A jak widzisz oba emaile nie są poprawne.
komentarz 27 listopada 2016 przez gipsy222 Nowicjusz (120 p.)
e(x)ample/@gmail.com walidacji nie przechodzi (sprawdziłem). Więc twój kontrprzykład jest obalony.
komentarz 27 listopada 2016 przez Assasz Nałogowiec (30,460 p.)
Wybacz, opierałem się na definicji a sam tego nie testowałem. Możliwe, że po prostu walidacja została ulepszona i pełni teraz również rolę sanityzacji.
0 głosów
odpowiedź 27 listopada 2016 przez HaKIM Szeryf (87,590 p.)
edycja 27 listopada 2016 przez HaKIM

IMO. jest to przeciwko SQL Incjetion i temu podobnych.

Choć, w sumie to nie widzę w tej sytuacji sensu. Zapewne miało to zaprezentować filtry dla e-mail, czy cusik...

Może źle do tego podszedłem (Późno jest!), ale popełniłem taki kod:

<?php

$emailToValidate = "kokodzambo@gmail.com' AND email IS NULL; --";

$sanitzeEmail = filter_var($emailToValidate, FILTER_SANITIZE_EMAIL);
$validateEmail = filter_var($emailToValidate, FILTER_VALIDATE_EMAIL);

if ($validateEmail == true) {
    print 'Success!' . "\n";
} else {
    print 'Your e-mail: ' . $emailToValidate . ' is not correct!' . "\n";
}

print "Sanitazed e-mail: " . $sanitzeEmail . "\n";
print "Validated e-mail: " . $validateEmail . "\n";

Output:

Your e-mail: kokodzambo@gmail.com' AND email IS NULL; -- is not correct!
Sanitazed e-mail: kokodzambo@gmail.com'ANDemailISNULL--
Validated e-mail: 

Sanitazed przepuszcza as well.

 Obraduję za:

Zapewne miało to zaprezentować filtry dla e-mail, czy cusik..

 Albo... Mam inną teorię:

$emailToValidate = "kokodżambo@gmail.com";

$sanitzeEmail = filter_var($emailToValidate, FILTER_SANITIZE_EMAIL);
$validateEmail = filter_var($emailToValidate, FILTER_VALIDATE_EMAIL);

if ($validateEmail == true) {
    print 'Success!' . "\n";
} else {
    print 'Your e-mail: ' . $emailToValidate . ' is not correct!' . "\n";
}

print "Sanitazed e-mail: " . $sanitzeEmail . "\n";
print "Validated e-mail: " . $validateEmail . "\n";

Meh.

Your e-mail: kokodżambo@gmail.com is not correct!
Sanitazed e-mail: kokodambo@gmail.com
Validated e-mail: 

FILTER_VALIDATE_EMAIL sobie radzi. Nie mam pojęcia po co tam sanityzacja.

Ten kod jest naprawdę elegancki i do bólu logiczny.

A jednak. cheeky

Np. jeśli użyjesz samej walidacji email e(x)ample/@gmail.com byłby ok. Natomiast z samą sanityzacją example@gmail byłby ok. A jak widzisz oba emaile nie są poprawne.

Pyknąłem w kod powyżej:

$emailToValidate = "e(x)ample/@gmail.com";

$sanitzeEmail = filter_var($emailToValidate, FILTER_SANITIZE_EMAIL);
$validateEmail = filter_var($emailToValidate, FILTER_VALIDATE_EMAIL);

if ($validateEmail == true) {
    print 'Success!' . "\n";
} else {
    print 'Your e-mail: ' . $emailToValidate . ' is not correct!' . "\n";
}

print "Sanitazed e-mail: " . $sanitzeEmail . "\n";
print "Validated e-mail: " . $validateEmail . "\n";

Output:

Your e-mail: e(x)ample/@gmail.com is not correct!
Sanitazed e-mail: example@gmail.com
Validated e-mail:  

Samo:  FILTER_VALIDATE_EMAIL znowu dało sobie radę.

Chyba, że tutaj FILTER_SANITIZE_EMAIL to taki objaw troski, gdy ktoś jednak pokosi się o te nawiasy czy inne wygibasy. 

komentarz 27 listopada 2016 przez gipsy222 Nowicjusz (120 p.)
sprawdziłem czy slash ( / ) przechodzi walidację i przechodzi. Zgadza się to z Mirka opisem dozwolonych znaków, gdzie / to dozwolony znak. Jeżeli jednak poprzedzę walidacje sanityzacją to ona okroi mi slash'a i mój mail został popsuty. Pytanie brzmi więc: Dlaczego slash (może jakiś inny symbol ale nie specjalnie dostrzegam jaki) jest w sanityzacji usuwany? Czy może on powodować jakieś luki w bezpieczeństwie? Nawet jeśli to walidacja mogłaby go uznać jako symbol niedozwolony.

Poza tym ta sanityzacja filtrem to tylko jakieś usuwanie znaków a nie jak w mysqli_escape_string(connection, string) na przykład dodawanie dodatkowego backslasha przed symbolami powodujacymi mysql injection.

Mirek wypowiedz się :p

PS. można tu dodac jakiegoś taga, żeby kogoś postymulować do odpowiedzi ?

Podobne pytania

0 głosów
0 odpowiedzi 877 wizyt
pytanie zadane 29 marca 2019 w PHP przez MrxCI Dyskutant (8,260 p.)
+1 głos
1 odpowiedź 286 wizyt
pytanie zadane 7 stycznia 2022 w PHP przez Avernis Nałogowiec (27,400 p.)
0 głosów
0 odpowiedzi 393 wizyt
pytanie zadane 31 maja 2020 w JavaScript przez boneoflive Użytkownik (930 p.)

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

61,940 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!

...