我正在尝试设置一个Cookie来记住用户(为期3天),这样他们就无需在每次关闭浏览器时都登录网站。
我尝试了以下内容:
<?php
if(isset($_POST["logind_ok_tjek"]))
{
if ($stmt = $this->mysqli->prepare("SELECT `id`, `rank_hold`, `navn`, `efternavn`, `email_indhold`, `adgangskode`, `rank`, `img` FROM `bruger` WHERE `email_indhold` = ? or tlf = ? AND `adgangskode` = ?"))
{
$stmt->bind_param('sss', $email_indhold, $tlf, $adgangskode);
$email_indhold = $_POST["email"];
$tlf = $_POST["email"];
$adgangskode = sha1($_POST["pass"]);
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($id, $rank_hold, $navn, $efternavn, $email_indhold, $adgangskode, $rank, $img);
$stmt->fetch();
$count = $stmt->num_rows;
$stmt->close();
if($count > 0)
{
$_SESSION["logged_in"] = true;
$_SESSION["id"] = $id;
$_seesion["rank_hold"] = $rank_hold;
$_SESSION["navn"] = $navn . " " . $efternavn;
$_SESSION["rank"] = $rank;
$_SESSION["img"] = $img;
$_SESSION["mail"] = $email_indhold;
setcookie("Navn", $navn . " " . $efternavn, time()+3600);
setcookie("indhold", $rank_hold, time()+3600);
if($_SESSION["logged_in"] == true)
{
if ($stmt = $this->mysqli->prepare('UPDATE `bruger` SET `online_sidste`=? WHERE `id`=?')) {
$stmt->bind_param('si', $online_sidste, $id);
$online_sidste = date('Y-m-d H:i:s');
$id = $_SESSION["id"];
$stmt->execute();
echo "Log ind nu!!";
$stmt->close();
} else {
echo 'Der opstod en fejl i erklæringen: ' . $mysqli->error;
}
}
else
{
echo "Fejl..";
}
}
else
{
echo "Forkert Email eller password.";
}
}
}
?>
要访问cookie,我正在使用:
<?php
echo $_COOKIE["Navn"];
?>
这不起作用,但是......
答案 0 :(得分:0)
//设置一个在72小时后到期的cookie,你可以试试这个
setcookie("Navn", $navn . " " . $efternavn, time()+3600*72);
setcookie("indhold", $rank_hold, time()+3600*72);
setcookie
函数expire
参数取值为秒。time()
将输出当前unix_timestamp
,然后您添加3600 * 72(3600秒* 72小时)相当于3天(以秒为单位)。