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

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 Aktualny czas: 22.08.2025 - 06:48