Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php]logowanie z sesjami i ciasteczkami
Forum PHP.pl > Forum > PHP
pentel
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.
strife
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.
pentel
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
Dalrin
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
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.