我正在尝试使用 cookie 来保持我网站上的登录持久性。但是,由于某种我不知道的原因,cookie 没有被创建。仅创建会话。我正在使用 Sessions 来跟踪登录的用户,并使用 cookie 在他们回来时重新创建会话。我究竟做错了什么?
创建会话和 cookie:
<?php
$connect= // connect variables
$query= "SELECT * FROM users where email= '$email' AND password=
'$password'";
$result= mysqli_query($connect, $query)
or die('error with query');
if (mysqli_num_rows($result) == 1) {
$row= mysqli_fetch_array($result);
session_start();
$_SESSION['id']= $row['user_id'];
$_SESSION['name']= $row['fname'] . " " . $row['lname'];
setcookie('id', $row['user_id']);
$profile_url= 'http://'. $_SERVER['HTTP_HOST'] .
dirname($_SERVER['PHP_SELF']) . '/profile.php';
header('Location:profile.php');
}
else {
$message= "Incorrect email/password combination.";
}
?>
检查 cookie 以恢复会话:
<?php
session_start()
/* if a session does not exist, see if a cookie does to set the session */
if (!isset($_SESSION['id'])) {
if (isset($_COOKIE['id'])) {
$_SESSION['id'] = $_COOKIE['id'];
}
else {
}
}
?>
编辑
我需要在 cookie 中添加一个过期参数!
setcookie('id', $row['user_id'],time()+86400);
Note: The above example sets the cookie for 1 day