Cookie is not being set - PHP


Cookie is not being set - PHP

**更新-问题已解决**我的代码是正确的,只是我需要指定目录。设置cookie的文件位于子域中,因此跳过根目录。我更改了代码,将cookie设置为:

setcookie('Remember','remembercheck',time()+3600,'/','.mydomain.com');

现在设置正确。

**结束更新**

当我尝试在不选中"记住我"按钮的情况下登录时,cookie没有设置,我也没有登录。如果我在选中"记住"按钮的状态下登录,它会正常登录。有什么想法吗?我被难住了!

PHP:

<?php
require 'connect.php';
require 'functions.php';
session_name('login');
session_start();
// ---------- LOGIN ---------- 
if($_POST['submit']=='Login')
{   
    // Checking whether the Login form has been submitted
    $err = array();
    // Will hold our errors

    if(!$_POST['username'] || !$_POST['password'])
        $err[] = 'All the fields must be filled in!';
    if(!count($err))
    {
        $_POST['username'] = mysql_real_escape_string($_POST['username']);
        $_POST['password'] = mysql_real_escape_string($_POST['password']);
        $_POST['remembercheck'] = (int)$_POST['remembercheck'];
        $storedsaltquery = mysql_fetch_assoc(mysql_query("SELECT rand FROM membertable WHERE usr = '".$_POST['username']."'"));
        $storedsalt = $storedsaltquery['rand'];
        // Escaping all input data
        $row = mysql_fetch_assoc(mysql_query("SELECT id,usr, FROM membertable WHERE usr='{$_POST['username']}' AND pass='{$_POST['password']}'"));
        if($row['id'])
        {
            // If everything is OK login
            $_SESSION['usr']=$row['usr'];
            $_SESSION['id'] = $row['id'];
            $_SESSION['remembercheck'] = $_POST['remembercheck'];
            // Store some data in the session
            setcookie("Remember","remembercheck");
        }
        else $err[]='Wrong username and/or password!';
    }
    if($err)
    $_SESSION['msg']['login-err'] = implode('<br />',$err);
    // Save the error messages in the session
    echo header("Location: ../index.php");
    exit;
}

HTML:

<?php
require 'includes/connect.php';
require 'includes/functions.php';
session_name('crmLogin');
// Starting the session
session_start();
if($_SESSION['id'] && !isset($_COOKIE['Remember']) && !$_SESSION['remembercheck'])
{
    // If you are logged in, but you don't have the Remember cookie (browser restart)
    // and you have not checked the remembercheck checkbox:
    $_SESSION = array();
    session_destroy();
    // Destroy the session
}

if(isset($_GET['logoff']))
{
    $_SESSION = array();
    session_destroy();
    header("Location: index.php");
    exit;
}
?>
    <form name="login" action="includes/logincheck.php" method="post">
                Username: <input type="text" name="username" id="username" /><br>
                Password: <input type="password" name="password" id="password" /><br>
                <input name="remembercheck" id="remembercheck" type="checkbox" checked="checked" value="1" />&nbsp;&nbsp;Remember Me&nbsp;&nbsp;
                <input type="submit" value="Login" name="submit"/><br><br><br>
   </form>

使用setcookie函数,我们应该设置一个到期时间

请查看描述:

boolsetcookie(string$name[,string$value[,int$expire=0[,stringe$path[,strig$domain[,bool$securite=false[,bool$httponly=false]]]](

到期

cookie过期的时间。这是Unix时间戳,所以是数字自纪元以来的秒数。换句话说,你很可能这与time((函数加上之前的秒数希望它过期。或者您可以使用mktime((。时间((+60*60*24*30将将cookie设置为30天后过期。如果设置为0或忽略cookie将在会话结束时过期(当浏览器关闭(。

所以你应该这样做:

setcookie("pfRemember","rememberPFcheck",time() + 3600)

更多关于php.net 的信息