Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MySQL][PHP] Logowanie. While powiela komunikat...
Bureau
post 10.04.2012, 01:12:01
Post #1





Grupa: Zarejestrowani
Postów: 26
Pomógł: 0
Dołączył: 18.03.2012

Ostrzeżenie: (0%)
-----


Siemanko.

Napisałem sobie prosty skrypt logowania.
Skrypt po zalogowaniu przekierowywuje na index2.php poprzez header().
Niestety gdy używam else aby wyświetlić niepowodzenie operacji, to while mi powiela komunikat.
Dzieje się chyba dlatego ponieważ sprawdzam dwie zmienne ? Nie wiem dokładnie.

Kod przedstawia się następująco:
  1. <?php
  2. if (isset($_POST['submit'])) {
  3. $conn = mysqli_connect("localhost", "", "", "test");
  4.  
  5. $login = $_POST['login'];
  6. $haslo = $_POST['haslo'];
  7.  
  8. $zapytanie = "SELECT * FROM uzytkownicy";
  9. $data = mysqli_query($conn, $zapytanie) or die("MySQL error: " . mysqli_error($conn) . "<hr>\nQuery: $zapytanie");
  10.  
  11. if ($zapytanie) {
  12. while ($row = mysqli_fetch_array($data)) {
  13. if ($login == $row['login'] || $haslo == $row['haslo']) {
  14.  
  15. $_SESSION['zalogowany'] = true;
  16. header("location:index2.php");
  17.  
  18. }
  19. else {
  20. ?>
  21. Niepoprawne dane. Zaloguj sie ponownie!
  22. <a href="logowanie.php" >Logowanie</a>
  23. <?
  24. }
  25.  
  26.  
  27. }
  28.  
  29.  
  30. }
  31.  
  32. }
  33. else {
  34. ?>
  35.  
  36. <form action="logowanie.php" method="post" />
  37. <input name="login" />
  38. <input name="haslo" />
  39. <input type="submit" name="submit" value="Zaloguj" />
  40. </form>
  41.  
  42. <?php
  43. }
  44. ?>


Komunikat:
Kod
Niepoprawne dane. Zaloguj sie ponownie!
<a href="logowanie.php" >Logowanie</a>


Zostaje powielany.
Wiem że jest on w petli, ale jak jest gdzie indziej to nie działa smile.gif
Chciałem zastosować też header(), ale wtedy nawet gdy podam poprawne dane w formularzu to przekierowuje mnie na logwanie.php bez sesji...

Da sie to jakos inaczej wyświetlić ? Próbowałem foreach, ale niestety dzialania tej instrukcji nie kumam do końca.

Dzięki za odpowiedzi smile.gif

Pozdrawiam!
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
Bureau
post 10.04.2012, 13:23:56
Post #2





Grupa: Zarejestrowani
Postów: 26
Pomógł: 0
Dołączył: 18.03.2012

Ostrzeżenie: (0%)
-----


Cytat(camikazee @ 10.04.2012, 13:01:20 ) *
Trzeba zacząć od analizy gotowych kodów i przyjąć pewną logikę.
Postaram się Tobie wytłumaczyć jak to powinno wyglądać.

1. Pobieram od użytkownika login oraz hasło
2. Sprawdzam jednym zapytaniem czy istnieje w bazie user o takim loginie i takim haśle
3. Istnieje, to przekierowuję, nie wyświetlam błąd

U Ciebie jest tak
1. Pobieram wszystkich użytkowników z bazy
2. Sprawdzam czy do któregoś pasuje login lub hasło (ta zasadnicza różnica pomiędzy || a && - || oznacza że obojętnie który warunek musi być spełniony czyli w Twoim przypadku wystarczy, że znajdzie uzytkownika o danym loginie lub danym haśle i nie muszą wcale one pasować do siebie, && oznacza, że szuka usera, który ma login jakiś tam i hasło przypisane i oba warunki muszą być spełnione)
3. Dla każdego użytkownika pobranego, jeżeli hasło i login nie pasują wyświetlam błąd

Widzisz różnicę?

Po co pobierać wszystkich użytkowników, jak szukasz tylko jednego?
I pamiętaj, jak coś nie działa, to nie dlatego, że jest złe w swym założeniu, tylko Ty źle to zbudowałeś.


Tak, widzę różnicę smile.gif
Dzięki za wytłumaczenie smile.gif

Tylko teraz jak już sprawdze czy dany user istnieje w bazie (Twoim sposobem) to co dalej ?

  1. if ($zapytanie) {
  2. przekierowanie do indexu
  3. } else {
  4. przekierowanie na formularz logowania
  5. }


EDIT ////////

Do przykładowego wyświetlania po zapytaniu użyłem:

  1. $row = mysqli_fetch_array($data);
  2. echo "Twoje id to" . $row['id'];


Chciałem sprawdzic na szybko czy dobrze czyta uzytkowników.
Teraz kwestia tego żeby wyświetlić error w przypadku podania złych danych lub gdy sa one prawidlowe uzycia header() lub innego przekierowania.
Chodzi tu chyba tylko jaki warunek dac w if, aby rozpoznawalo kiedy ma przekierowac a kiedy wyswietlic blad.

Ten post edytował Bureau 10.04.2012, 13:43:22
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 19:17