![]() |
![]() ![]() |
![]() |
![]()
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:
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 ![]() 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 ![]() Pozdrawiam! |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 47 Pomógł: 2 Dołączył: 26.03.2010 Ostrzeżenie: (0%) ![]() ![]() |
|
|
|
![]()
Post
#3
|
|
![]() Grupa: Zarejestrowani Postów: 2 355 Pomógł: 533 Dołączył: 15.01.2010 Skąd: Bydgoszcz Ostrzeżenie: (0%) ![]() ![]() |
A do czego służy Ci ten while w 13 linijce?
|
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 171 Pomógł: 18 Dołączył: 17.04.2006 Skąd: Bydgoszcz Ostrzeżenie: (0%) ![]() ![]() |
Dziwny skrypt, podglądałeś w internecie jak "prawidłowo" wykonać skrypt logowania? Po co pobierać wszystkich userów z bazy i w pętli sprawdzać czy pasuje hasło i login do któregoś?
Przykładowo:
Oczywiście pomijam kwestię bezpieczeństwa powyższego kodu. Kolejna sprawa, koduj hasła choćby w MD5. A teraz ostatnia kwestia, zobacz masz w bazie 100 userów, logujesz, 99 pierwszych nie pasuje do szukanego login, hasło, więc wyświetli komunikat o błędzie, setny zaś pasuje, ale przekierowania już nie zrobi, bo wyświetlił informacje o wcześniejszym błędzie. Ten post edytował camikazee 10.04.2012, 11:54:58 -------------------- www.fachoweuslugi.pl | www.zlec-usluge.pl | www.pokazsie.pl
|
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 26 Pomógł: 0 Dołączył: 18.03.2012 Ostrzeżenie: (0%) ![]() ![]() |
A przypadkiem linia 14 nie powinna wyglądać o tak ?
To chyba nic nie zmienia ? ![]() ![]() Cytat A do czego służy Ci ten while w 13 linijce? Ten while ? Tak szczrze to chciałbym się go pozbyć, bo to takie moje przyzwyczajenie w pisaniu wyświetlania ![]() Jakim sposobem mogę inaczej to zapisać aby nie była to pętla ? Bo zdaje mi się że to ona powiela mi komunikat i są same problemy... Cytat Dziwny skrypt. Oczywiście pomijam kwestię bezpieczeństwa powyższego kodu. Kolejna sprawa, koduj hasła choćby MD5. A teraz ostatnia kwestia, zobacz masz w bazie 100 userów, logujesz, 99 pierwszych nie pasuje do szukanego login, hasło, więc wyświetli komunikat o błędzie, setny zaś pasuje, ale przekierowania już nie zrobi, bo wyświetlił informacje o wcześsiejszym błędzie. Co do bezpieczeństwa to wiem, jest paskudnie, ale to tak na szybko pisany z pamięci kod. Ucze sie php, wiem tez ze w md5 koduje sie hasla do bazy i odwrotnie ![]() ![]() ![]() Twoje zapytanie miałem wbite w kod, ale nie działało bo nie dawałem chyba średników ![]() Jak mogę to zrobić bez pętli ? Po prostu po wykonaniu zapytania zamiast while dać:
? Pozdrawiam! Ten post edytował Bureau 10.04.2012, 10:33:34 |
|
|
![]()
Post
#6
|
|
![]() Grupa: Zarejestrowani Postów: 171 Pomógł: 18 Dołączył: 17.04.2006 Skąd: Bydgoszcz Ostrzeżenie: (0%) ![]() ![]() |
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ś. Ten post edytował camikazee 10.04.2012, 12:03:33 -------------------- www.fachoweuslugi.pl | www.zlec-usluge.pl | www.pokazsie.pl
|
|
|
-md5_jest_slabe- |
![]()
Post
#7
|
Goście ![]() |
md5 na obecne standardy jest uznawany za słaby algorytm hashujący i ma dość rozbudowaną bazę hashy, więc nie należy go stosować
https://www.owasp.org/index.php/Password_Storage_Cheat_Sheet zainteresuj się raczej PHPass używanym przez wordpress, phpbb3 i inne duże skrypty |
|
|
![]()
Post
#8
|
|
Grupa: Zarejestrowani Postów: 26 Pomógł: 0 Dołączył: 18.03.2012 Ostrzeżenie: (0%) ![]() ![]() |
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ę ![]() Dzięki za wytłumaczenie ![]() Tylko teraz jak już sprawdze czy dany user istnieje w bazie (Twoim sposobem) to co dalej ?
EDIT //////// Do przykładowego wyświetlania po zapytaniu użyłem:
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 |
|
|
![]()
Post
#9
|
|
![]() Grupa: Zarejestrowani Postów: 171 Pomógł: 18 Dołączył: 17.04.2006 Skąd: Bydgoszcz Ostrzeżenie: (0%) ![]() ![]() |
Nie, nadal nie zrozumiałeś.
-------------------- www.fachoweuslugi.pl | www.zlec-usluge.pl | www.pokazsie.pl
|
|
|
![]() ![]() |
![]() |
Wersja Lo-Fi | Aktualny czas: 12.07.2025 - 05:44 |