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

Cloud VPS
0 głosów
209 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 635 wizyt
pytanie zadane 17 września 2019 w PHP przez progNewbie Obywatel (1,130 p.)
0 głosów
0 odpowiedzi 185 wizyt
pytanie zadane 11 czerwca 2016 w PHP przez MatiiTv Gaduła (3,800 p.)
+1 głos
2 odpowiedzi 1,311 wizyt
pytanie zadane 4 stycznia 2016 w PHP przez Mavimix Dyskutant (8,420 p.)

93,469 zapytań

142,404 odpowiedzi

322,715 komentarzy

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

Kursy INF.02 i INF.03
...