Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP] porónywanie stringów z bazy danych i z formularza
charli_22
post 19.03.2008, 11:13:56
Post #1





Grupa: Zarejestrowani
Postów: 21
Pomógł: 0
Dołączył: 10.03.2008

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


Witam
Mam problem z porównaniem stringu z bazy danych i z formularza. Tu jest fragment kodu odpowiedzialny za to porównanie:

  1. <?php
  2. $email=$_POST['email'];
  3. $passwd=$_POST['passwd'];
  4.  
  5. while ($row=mysql_fetch_assoc($result)) {
  6. $row_login=$row['email'];
  7. $row_pass=$row['passwd'];
  8. $porownanie=strcmp($row_pass, $passwd); //sprawdzam co zwraca funkcja
  9. echo 'Funkcja zwróciła: ' . $porownanie;
  10. if(!(strcmp($row_pass, $passwd))) {
  11. $_SESSION['email'] = $row_login;
  12. $_SESSION['passwd'] = $row_pass;
  13. echo 'Zostałeś zalogowany.';
  14. } else {
  15. echo 'login nie powiodł się';
  16. }
  17. }
  18. ?>


Chodzi o to, że przy porównywaniu stringa pochodzącego z formularza ze stringiem pobieranym z bazy danych zwraca mi -1 a powinno 0, bo stringi są takie same. W bazie mam kodowanie UTF8.

Ten post edytował charli_22 19.03.2008, 11:50:50


--------------------
Test-Com - blog o testowaniu
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
charli_22
post 19.03.2008, 13:37:48
Post #2





Grupa: Zarejestrowani
Postów: 21
Pomógł: 0
Dołączył: 10.03.2008

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


Problem był z bazą danych. W phpMyAdmin ustawiłem dla pola hasło Typ MIME na text/plain. I gdy sprawdziłem długość hasła wpisywanego przez usera i tego z bazy za pomocą strlen() to różniły się długością o 1. Ustawiłem w bazce Typ MIME na pusty i długość zwracana przez strlen() jest identyczna dla jednego i drugiego stringu.

Zgodnie z zaleceniem zajme się hashowaniem haseł. Obecnie ucze się pisania skryptów i odpuściłem hashowanie, bo wszystko odbywa się lokalnie:), więc nie ma strachu, że ktoś się wpisze a ja podejrze jego hasło czy ktoś w sieci.

Dzięki za porady. Pozdrawiam. guitar.gif


--------------------
Test-Com - blog o testowaniu
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 - 15:26