无法让setcookie()正常工作

时间:2016-09-25 23:45:07

标签: php cookies setcookie

我编写了以下类,Cookie.php

class Cookie extends Config{

//Variables declaration
private $cookieName;
private $cookieValue;
private $cookieExpireTime;
private $cookiePath;
private $cookieDomain;
private $cookieSecureThroughSSL;
private $cookieOnlyThroughHTTP;

//Constructor method, creates a new cookie with the assigned values
function __construct($presetCookieName,
                     $presetCookieValue,
                     $presetCookieExpireTime,
                     $presetCookiePath='/',
                     $presetCookieDomain = NULL,
                     $presetCookieSecureThroughSSL = false,
                     $presetCookieOnlyThroughHTTP = true){

    $this->cookieName = $presetCookieName;
    $this->cookieValue = $presetCookieValue;
    $this->cookieExpireTime = $presetCookieExpireTime;
    $this->cookiePath = $presetCookiePath;
    $this->cookieDomain = $presetCookieDomain;
    $this->cookieSecureThroughSSL = $presetCookieSecureThroughSSL;
    $this->cookieOnlyThroughHTTP = $presetCookieOnlyThroughHTTP;

    return $this->createCookie();
}

//Clean cookie from possible malicious HTML code, or mistakenly typed spaces
private function cleanCookieValue($value){
    return htmlspecialchars(str_replace(' ', '', $value));
}

//Create a new cookie function
public function createCookie(){
    return setcookie($this->cleanCookieValue($this->cookieName),
                     $this->cleanCookieValue($this->cookieValue),
                     $this->cleanCookieValue($this->cookieExpireTime),
                     $this->cleanCookieValue($this->cookiePath),
                     $this->cleanCookieValue($this->cookieDomain),
                     $this->cleanCookieValue($this->cookieSecureThroughSSL),
                     $this->cleanCookieValue($this->cookieOnlyThroughHTTP));
}

以下测试文件:

$cookie = new Cookie("testCookie", "Value", 3600, "/");

if(isset($_COOKIE['testCookie'])){
    echo 'Success';
}
else{
    echo 'Failed!';
}

我不断收到'失败'错误(经过两次或更多次刷新后)。 你们在这看到问题吗?

顺便说一下,下面这个简单的例子很有效:

setcookie("token", "value", time()+60*60*24*100, "/");

if(isset($_COOKIE['token'])){
    echo 'Token succeeded';
}
else{
    echo 'Token failed!';
}

1 个答案:

答案 0 :(得分:0)

在课堂上,您发布的第三个参数是$presetCookieExpireTime,而不是"生命的秒数"。为了使它工作 - 做

$cookie = new Cookie("testCookie", "Value", time() + 3600, "/");