Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP][MySQL] Przechowywanie nazwy użytkownika w sesji
mentoos
post
Post #1





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 5.09.2009

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


Piszę klasę do obsługi użytkowników. Czy jest to bezpieczny sposób, żeby po prawidłowym zalogowaniu stworzyć dwie sesje jedną do wyświetlania nazwy użytkownika, drugą do sprawdzania. np.

  1. <?php
  2.  
  3. if ($username == $this->username AND $this->compare($password, $this->password, $this->salt))
  4. {
  5. $_SESSION['user'] = TRUE;
  6. $_SESSION['username'] = $this->username;
  7. return true;
  8. }
  9.  
  10. ?>


Czy stosowanie session_regenerate_id() przed session_destroy() jest najbezpieczniejszym sposobem na wylogowanie?

  1. <?php
  2.  
  3.  
  4. ?>
Go to the top of the page
+Quote Post
posiadacz
post
Post #2





Grupa: Zarejestrowani
Postów: 46
Pomógł: 2
Dołączył: 2.04.2009

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


Ja bym stworzył tablicę przechowującą dane o userze w sesji i podczas wylogowywania po prostu ją usunął.
Nie kasuj sesji, może będziesz przechowywać w niej jakieś inne przydantne użytkownikowi informacje - taka jest moja propozycja.

  1. $_SESSION['user'] = array('role' => 'admin', 'id' => 123, 'name' => 'posiadacz');
  2.  
  3. logout(){
  4. if(array_key_exists($_SESSION, 'user')){
  5. unset($_SESSION['user']);
  6. }
  7. }
  8.  
Go to the top of the page
+Quote Post

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 Aktualny czas: 20.08.2025 - 10:00