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

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
192 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 572 wizyt
pytanie zadane 17 września 2019 w PHP przez progNewbie Obywatel (1,130 p.)
0 głosów
0 odpowiedzi 181 wizyt
pytanie zadane 11 czerwca 2016 w PHP przez MatiiTv Gaduła (3,800 p.)
+1 głos
2 odpowiedzi 1,205 wizyt
pytanie zadane 4 stycznia 2016 w PHP przez Mavimix Dyskutant (8,420 p.)

93,173 zapytań

142,184 odpowiedzi

321,968 komentarzy

62,502 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 1157p. - dia-Chann
  2. 1139p. - Łukasz Piwowar
  3. 1131p. - CC PL
  4. 1126p. - Łukasz Eckert
  5. 1118p. - Tomasz Bielak
  6. 1104p. - Michal Drewniak
  7. 1083p. - Marcin Putra
  8. 1078p. - rucin93
  9. 1071p. - rafalszastok
  10. 1054p. - Adrian Wieprzkowicz
  11. 1047p. - Piotr Aleksandrowicz
  12. 1037p. - Michał Telesz
  13. 1017p. - Mikbac
  14. 1005p. - ssynowiec
  15. 992p. - Dominik Łempicki (kapitan)
Szczegóły i pełne wyniki

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

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...