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

Czy mogę używać preg_match w celu walidacji zamiast...

Object Storage Arubacloud
0 głosów
169 wizyt
pytanie zadane 14 grudnia 2017 w PHP przez White Cat Nowicjusz (160 p.)
Witajcie. Czy mogę używać preg_match w celu walidacji formularza zamiast użyć wcześniej isseta czy empty. Skoro przez preg_match coś nie przejdzie a zawierają się w nim dozwolone znaki i ich minimalna i maksymalna długość ?

Pozdrawiam i czekam na odpowiedz.

1 odpowiedź

0 głosów
odpowiedź 14 grudnia 2017 przez mtk3d Nałogowiec (46,690 p.)

Nie podałeś kodu, ale strzelam, że jeśli usuniesz isset(), to otrzymasz błąd dotyczący nieistniejącego indexu. Najlepiej będzie jak pokażesz swój kod.

komentarz 14 grudnia 2017 przez White Cat Nowicjusz (160 p.)

Nie deklaruję zmiennej do której przypisuję posta przed sprawdzeniem czy się zgadza. Dopiero po preg_matchu jeśli jest ok przypisuję ów zmienne. Więc błędu o indeksach nie ma.

if(preg_match('/^[a-zA-Z0-9]{5,15}$/',$_POST['login']) and preg_match('/^[a-zA-Z0-9]{10,15}$/',$_POST['haslo']) and preg_match('/^[a-zA-Z0-9]{5,15}$/',$_POST['pseudonim']) and preg_match('/^[a-zA-Z0-9]{10,15}$/',$_POST['haslo2']) and preg_match('/^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.]{2,6})$/',$_POST['email']) and $_POST['haslo'] == $_POST['haslo2']) 
    
    {
        
        $login = $_POST['login'];
        $haslo = md5($_POST['haslo']);
        $pseudonim = $_POST['pseudonim'];
        $email = $_POST['email'];
        $ip = $_SERVER['REMOTE_ADDR'];
        
        global $baza;
        
        
        $l = 0; $p = 0; $e =0;
        
        if(mysqli_num_rows(mysqli_query($baza, "SELECT login FROM uzytkownicy WHERE login = '$login'")))          
        
        {
            echo "Użytkownik o podanym loginie już istnieje.".'</br>';
            $l++;
        }
            
        if (mysqli_num_rows(mysqli_query($baza, "SELECT pseudonim FROM uzytkownicy WHERE pseudonim = '$pseudonim'")))
        
        {
            echo "Użytkownik o podanym pseudonimie już istnieje.".'</br>';
            $p++;
        }
        
        if (mysqli_num_rows(mysqli_query($baza, "SELECT email FROM uzytkownicy WHERE email = '$email'")))
        
        {
            
            echo "Użytkownik o podanym emailu już istnieje.".'</br>';
            $e++;
        }
        
        
        
        if($l == 0 and $p == 0 and $e == 0)
            
        {
            
            if(mysqli_query($baza, "INSERT INTO `uzytkownicy` (`id`, `login`, `haslo`, `pseudonim`, `ip`, `email`, `premium`) VALUES (NULL, '$login', '$haslo', '$pseudonim', '$ip', '$email', '0')")) 
            echo "Gratulacje. Zostałeś zarejestrowany.";
            else echo "Przykro nam. Coś poszło nie tak.";
            
        }
        
        
        
    }
    
    else echo "Wprowadziłeś złe dane lub hasła nie zgadzają się.";

komentarz 14 grudnia 2017 przez mtk3d Nałogowiec (46,690 p.)

A próbowałeś to odpalić? Oczywiście, że zwraca 'Undefined index'. Przypisz te parametry przed funkcją warunkową i tam sprawdź, czy istnieją:

$login = isset($_POST['login']) ? $_POST['login'] : null;
...

i przy else daj "{ ... }" Stosuj jeden zapis wszędzie, bo to co tam jest dopisane, to kiepska praktyka.

komentarz 14 grudnia 2017 przez White Cat Nowicjusz (160 p.)
Chyba mam gdzieś obsługę błędów wyłączoną. :P Czyli sprawdzać issetem a potem resztę. Dzięki i pozdrawiam ;)

Podobne pytania

0 głosów
2 odpowiedzi 471 wizyt
pytanie zadane 17 września 2019 w PHP przez progNewbie Obywatel (1,130 p.)
0 głosów
0 odpowiedzi 175 wizyt
pytanie zadane 11 czerwca 2016 w PHP przez MatiiTv Gaduła (3,800 p.)
+1 głos
2 odpowiedzi 1,093 wizyt
pytanie zadane 4 stycznia 2016 w PHP przez Mavimix Dyskutant (8,420 p.)

92,758 zapytań

141,679 odpowiedzi

320,437 komentarzy

62,101 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

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!

...