Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP]PDO Sprawdzenie czy użytkownik i hasło istnieją w bazie
Forum PHP.pl > Forum > Przedszkole
bwl
Hej.

Próbuję tak:

  1. $user_query = $db->prepare('SELECT user FROM users WHERE user = ":user" AND pass = ":pass"');
  2. $user_query->bindValue(':user', $login, PDO::PARAM_STR);
  3. $user_query->bindValue(':pass', $haslo, PDO::PARAM_STR);
  4. $user_query->execute();
  5.  
  6. $istnienie_uzytkownika = $user_query->rowCount();
  7.  
  8. if ($istnienie_uzytkownika>0)
  9. {
  10. echo "znaleziono uzytkowniak";
  11. }
  12. else
  13. {
  14. echo "nie ma takiego uzytkownika";

Jednak bezskutecznie, zresztą nawet storm mi podkreśla user i pass.

Z góry dzięki smile.gif
Pyton_000
Pierwsza sprawa:
- nie używamy " jeśli są named parameters czyli zamiast `":user"` ma być `:user`

Kolejna sprawa to masz pobrać dane usera na podstawie loginu a potem w PHP sprawdzić czy zakodowane hasło w BD jest zgodne z zakodowanym hasłem przesłanym od użytkownika. Tu zależy w jaki sposób jest kodowane hasło.
bwl
Ok, poprawiłem, ale teraz wali błędem: Parse error: syntax error, unexpected ':', expecting ',' or ')'. Wcześniej połączenie działało, z tym, że if zawsze zwracał, że nie ma takiego uzytkownika.
W tej chwili nie jest kodowane w żaden sposób. Jakoś tak robię najpierw logowanie, dopiero później rejestrację... dane wpisałem do tabeli ręcznie.
leonpro778
Cytat(bwl @ 24.05.2018, 13:37:21 ) *
Ok, poprawiłem, ale teraz wali błędem: Parse error: syntax error, unexpected ':', expecting ',' or ')'. Wcześniej połączenie działało, z tym, że if zawsze zwracał, że nie ma takiego uzytkownika.
W tej chwili nie jest kodowane w żaden sposób. Jakoś tak robię najpierw logowanie, dopiero później rejestrację... dane wpisałem do tabeli ręcznie.


W której linii jest ten błąd? Kolejna sprawa, po co wyciągasz nazwę 'user' z bazy skoro jako parametr wyszukiwania podajesz 'user' ? Nie lepiej jest wyszukiwać id_user czy coś podobnego?
bwl
Zmieniłem na: 'SELECT user FROM users WHERE user=:user AND pass=:pass' i działa chociaż Storm nadal świeci.
Natomiast czy lepiej to ciężko mi odpowiedzieć, bo ja raczkuję dopiero wink.gif
Dzięki za pomoc.
leonpro778
Hehe, co znaczy Storm "świeci" biggrin.gif Używam Storma i mi nie świeci biggrin.gif Może masz źle skonfigurowanego? Co do zmiennych i ich podkreślania to najedź po prostu myszą i sprawdź dlaczego Ci Storm coś podkreśla.
bwl
No tak sobie mówię bo sobie taki oczoje... kolor ustawiłem wink.gif, ale chyba oboje wiemy o co chodzi.
Coś tam mi kolega konfigurował i inne podobne zapytania nie świecą.
Unable to resolve column 'user', i Unable to resolve table 'users'
Tu jeszcze przed zmianami, ale teraz jest tak samo.

Pyton_000
Bo musiałbyś sobie dodać połączenie do bazy w stormie i wtedy jest też podpowiadanie. Dodatkowo można sobie takie zapytanie odpalić (ctrl + enter) z parametrami i ręcznie wpisujesz paraetry.
bwl
Wydaje mi się, że baza jest podpięta i tak jak pisałem wcześniej inne podobne zapytania nie świecą.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.