记住用户好几天 - 饼干

时间:2013-09-25 20:23:19

标签: php cookies

我正在尝试设置一个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"];
         ?>

这不起作用,但是......

1 个答案:

答案 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天(以秒为单位)。