Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> odzyskiwanie hasła na e-mail a link
inomi13
post
Post #1





Grupa: Zarejestrowani
Postów: 95
Pomógł: 0
Dołączył: 16.08.2017

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


Stworzyłem formularz odzyskiwania hasła który wysyła na skrzynkę e-mailową nowe hasło a w bazie danych dodaje taki sam wpis w tabeli "pass_temp".
  1. $_SESSION['name'] = $wiersz['name'];
  2. $wynik= $polaczenie->query("SELECT pass from persons where email='$email'");
  3. $wiersz = $wynik->fetch_assoc();
  4. $wiersz['pass'] = str_shuffle("qwertyuiopasdfghjklzxcvbnm1234567890");
  5. $wiersz['pass'] = substr($wiersz['pass'],0,20);
  6. $haslo1=$wiersz['pass'];
  7. $haslo_hash = password_hash($haslo1, PASSWORD_DEFAULT);
  8. $zmiana = "UPDATE persons SET pass = '$haslo_hash', pass_temp = '$haslo_hash' WHERE email='$email'";


Osoba która otrzymuje e-maila klika w link "zmiana hasła" i może odrazu wpisać tymczasowe hasło, nowe i powtórzenie nowego hasła. Wszystko działa jednak jest problem w sytuacji jak dwie osoby w tym samym czasie chciały by odzyskać hasło. Proszę o jakieś sugestie

  1. require_once "connect.php";
  2. $polaczenie = @new mysqli($host, $db_user, $db_password, $db_name);
  3. $wynik= $polaczenie->query("SELECT user from persons where pass=pass_temp");
  4. $wiersz = $wynik->fetch_assoc();
  5. if(empty($wiersz["user"]))
  6. {
  7. header('Location: index.php');
  8. exit();
  9. }
  10. else
  11. {
  12. if(isset($_POST['ok']))
  13. {
  14.  
  15. $wszystko_OK=true;
  16. $user=$wiersz["user"];
  17. $haslo = $_POST['haslo'];
  18. $haslo1 = $_POST['haslo1'];
  19. $haslo2 = $_POST['haslo2'];
  20.  
  21.  


Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
gitbejbe
post
Post #2





Grupa: Zarejestrowani
Postów: 516
Pomógł: 63
Dołączył: 27.08.2012

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


strasznie to zagmatwane.

w ogóle po co jakieś tymczasowe hasło ? skoro - jak sam piszesz, użytkownik i tak je zmieni zaraz po zalogowaniu

User zapomniał hasła, klika w przycisk "resetuj hasło" i wpisuje adres email lub login dla którego ma zostać wysłany email z linkiem.

Link powinien zawierać token po którym strona zweryfikuje że ten użytkownik chce zmienić hasło, moze to wyglądać np:

www.jakastrona.pl/passreset?user=bolek&&token=idhasd12898sd9adjasd9022j1nndsa

to najprostsza wersja. Token generujesz haszując np email, login lub inne stałe dane użytkownika + sól. Klikając w link strona weryfikuje czy użytkownik istnieje, generuje token wg tego samego schematu co podczas tworzenia linka i porównujesz czy się zgadza. Jeśli jest ok, wyświetla formularz zmiany hasła gdzie podaje się już tylko nowe hasło i tyle.

można też zrobić oddzielną tablicę która zawiera tylko tokeny (przykładowa struktura: [id, userID, token, date]), łączysz ją relacją z tablicą users. Wtedy link mógłby już wyglądać tak:

www.jakastrona.pl/passreset?token=idhasd12898sd9adjasd9022j1nndsa

Plus jest taki że hash za każdym razem może być inny, bo masz go zapisanego w bazie. Po kliknięciu w link, sprawdzasz czy token istnieje w bazie i pobierasz dane użytkownika do którego został przypisany. Reszta bez zmian, jeśli jest ok, wyświetlasz formularz w którym user wpisuje nowe hasło. Jeśli chodzi o usuwanie wygasłych tokenów to w tym konkretnie przypadku możesz śmiało wykonywać to przed każdym sprawdzeniem tokena - cronjob nie ma sensu do takiego prostego zadania.
Go to the top of the page
+Quote Post

Posty w temacie


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

 



RSS Aktualny czas: 5.10.2025 - 01:11