Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [php]logowanie z sesjami i ciasteczkami, logowanie nie do końca poprawne
pentel
post
Post #1





Grupa: Zarejestrowani
Postów: 28
Pomógł: 0
Dołączył: 3.07.2007

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


Witam,
Moja strona działa na zasadzie includowania (przykładowy link ?x=home). Przed wysłaniem html i head wstawiłem logowanie. Problem jest właśnie w skrypcie na logowanie. Coś zrobiłem źle :(.

index.php (zostawiłem tylko to, co potrzebne):
  1. <?php
  2. include_once 'inc/access.php';
  3. ?>
  4. <html>
  5. <head>
  6. </head>
  7. <body>
  8. <!-- tu includuje sobie strony -->
  9. <!-- tu mam formularz logowania, który jest zawsze, niezależnie od wybranej podstron
    y -->
  10. </body>
  11. </html>


access.php:
  1. <?php
  2.  
  3. //session_id() = $_COOKIE['PHPSESSID']; //odkomentowane zwraca fatal error :/
  4. $_SESSION['auth'] = $_COOKIE['auth'];
  5. $_SESSION['user'] = $_COOKIE['user'];
  6. $_SESSION['pass'] = $_COOKIE['pass'];
  7. $_SESSION['level'] = $_COOKIE['level'];
  8.  
  9. if ( session_id() == '' ){
  10.  $formlogin = $_POST['formlogin'];
  11.  $formpassword = $_POST['formpassword'];
  12.  $mres_formlogin = mysql_real_escape_string($formlogin);
  13.  $md5_formpass = md5($formpassword);
  14.  if (!$formlogin || !$formpassword){
  15.  }
  16.  
  17.  $sql = "SELECT * FROM `users` WHERE `login` = '$mres_formlogin'"; // dlaczego jak umieszczam kod w [ php ][ /php ] to skrypt
  18.  //dodaje te ''? :/
  19.  $dbuser = mysql_query($sql);
  20.  
  21.  $array = mysql_fetch_assoc($dbuser);
  22.  $userid = $array['id'];
  23.  $userlogin = $array['login'];
  24.  $userpassword = $array['password'];
  25.  $userlevel = $array['level'];
  26.  
  27.  $md5_dbpass = md5($array['password']);
  28.  
  29.  if ( (mysql_num_rows($dbuser) == 1) && ($md5_formpass == $md5_dbpass) ){
  30. $_SESSION['auth'] = true;
  31. $_SESSION['user'] = $userlogin;
  32. $_SESSION['pass'] = $md5_dbpass;
  33. $_SESSION['level'] = $userlevel;
  34. include_once 'inc/cookie.php';
  35.  } else {
  36.  }
  37. }//end of if session_id
  38. ?>


cookie.php:
  1. <?php
  2. setcookie('auth', $_SESSION['auth'], time() + 300);
  3. setcookie('user', $_SESSION['user'], time() + 300);
  4. setcookie('pass', $_SESSION['pass'], time() + 300);
  5. setcookie('level', $_SESSION['level'], time() + 300);
  6. ?>


Jestem np. na stronie blablabla/?x=team i wpisując poprawne dane staję się zalogowany. Problem w tym, że gdy kliknę link do strony np. ?x=home (lub innej podstrony), to po przejściu na tą stronę już nie jestem zalogowany. Czyli jakby sesja nie spełnia swojego zadania. A chcę być zalogowany, aż do wygasnięcia ciasteczka, bądź wylogowania.
Jakieś pomysły? :) Pozdrawiam.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 3)
strife
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 2 605
Pomógł: 96
Dołączył: 22.10.2004
Skąd: UK

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


Niepotrzebnie w ciasteczku przechowujesz ( jak się domyślam ) wartość odpowiadającą za uprawnienia, ciasteczka można modyfikować i jak widzę, dostęp jako administrator, można uzyskać bardzo łatwo :]

Trochę ten Twój kod jest zagmatwany, użyj konstrukcji takich jak var_export" title="Zobacz w manualu PHP" target="_manual do sprawdzenia czy w tablicy $_SERVER są dane umożliwiąjące rozpoznanie użytkownika, upewnij się.

Dodaj session_start() na początku index.php, może być tak, że sesja nie jest widoczna.

Pozdrawiam.


--------------------
Go to the top of the page
+Quote Post
pentel
post
Post #3





Grupa: Zarejestrowani
Postów: 28
Pomógł: 0
Dołączył: 3.07.2007

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


No to z tymi ciasteczkami dałem ciała smile.gif

Teraz access.php wygląda tak:
  1. <?php
  2.  
  3. $formlogin = $_POST['formlogin'];
  4. $formpassword = $_POST['formpassword'];
  5. $mres_formlogin = mysql_real_escape_string($formlogin);
  6. $md5_formpass = md5($formpassword);
  7.  
  8. if ( $_SERVER['REQUEST_METHOD'] == 'POST' ){
  9.  if ($_SESSION['auth'] !== true){
  10. $_SESSION['user'] = $mres_formlogin;
  11. $_SESSION['pass'] = $md5_formpass;
  12.  }
  13. } else {
  14.  $_SESSION['user'] = $_COOKIE['user'];
  15.  $_SESSION['pass'] = $_COOKIE['pass'];
  16. }
  17.  
  18.  $sql = "SELECT * FROM `users` WHERE `login` = '" . $_SESSION['user'] . "'";
  19.  $dbuser = mysql_query($sql);
  20.  
  21.  $array = mysql_fetch_assoc($dbuser);
  22.  $userid = $array['id'];
  23.  $userlogin = $array['login'];
  24.  $userpassword = $array['password'];
  25.  $userlevel = $array['level'];
  26.  
  27.  $md5_dbpass = md5($array['password']);
  28.  
  29.  if ( (mysql_num_rows($dbuser) == 1) && ($_SESSION['pass'] == $md5_dbpass) ){
  30. $_SESSION['auth'] = true;
  31. $_SESSION['user'] = $userlogin;
  32. $_SESSION['pass'] = $md5_dbpass;
  33. $_SESSION['level'] = $userlevel;
  34. include_once 'inc/cookie.php';
  35.  }
  36. ?>

Zaś cookie.php tak:
  1. <?php
  2. if ( isset($formremember) ){ // sesja wygasnie za tydzien
  3.  setcookie('user', $_SESSION['user'], time() + 7 * 24 * 3600);
  4.  setcookie('pass', $_SESSION['pass'], time() + 7 * 24 * 3600);
  5. } else { // sesja wygasnie po zamknieciu przegladarki
  6.  setcookie('user', $_SESSION['user']);
  7.  setcookie('pass', $_SESSION['pass']);
  8. }
  9. ?>

Jakie jeszcze są tu dziury? smile.gif

Ten post edytował pentel 4.07.2007, 14:08:22
Go to the top of the page
+Quote Post
Dalrin
post
Post #4





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 14.04.2005
Skąd: Niedaleko

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


Witka,

No tak patrząc na szybko to nie jestem pewien czy to dobrze, że przetrzymujesz w cookie usera i hasło.

Nie ma raczej większego problemu z wyciągnieciem czegoś z pliku cookie i podszycia się pod takiego nieświadomego użytkownika.

Pozdrawiam

--
Dalrin

Ten post edytował Dalrin 24.08.2007, 13:58:49
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: 21.08.2025 - 18:24