Heim > Backend-Entwicklung > PHP-Tutorial > 关于YII Session与Cookie的有效期的问题和cookie与session的关系

关于YII Session与Cookie的有效期的问题和cookie与session的关系

WBOY
Freigeben: 2016-06-06 20:44:28
Original
1085 Leute haben es durchsucht

1.在YII的loginForm中间,有一个login方法用来设置记住用户名的时间:

<code class="lang-php">public function login()
    {
        if($this->_identity===null)
        {
            $this->_identity=new UserIdentity($this->username,$this->password);
            $this->_identity->authenticate();
        }
        if($this->_identity->errorCode===UserIdentity::ERROR_NONE)
        {
            $duration=$this->rememberMe ? 3600*24*10 : 0; // 10 days
            Yii::app()->user->login($this->_identity,$duration);
            return true;
        }
        else
            return false;
    }
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如上,假如我把$duration=$this->rememberMe ? 36002410 : 0; // 10 days,即我设置为10天。是cookie的有效期设置为10天,还是cookie和session的有效期都设置为10天呢?
我想把session的有效期设置10天。不知道在哪里可以设置。
还有一个问题,假如cookie是10天,session只有半个小时。第二天我带着cookie登录的时候,是不是PHP根据cookie生成了一个session。
还是php自动生成了session,然后把sessionID重新写回到cookie中间去呢?

回复内容:

1.在YII的loginForm中间,有一个login方法用来设置记住用户名的时间:

<code class="lang-php">public function login()
    {
        if($this->_identity===null)
        {
            $this->_identity=new UserIdentity($this->username,$this->password);
            $this->_identity->authenticate();
        }
        if($this->_identity->errorCode===UserIdentity::ERROR_NONE)
        {
            $duration=$this->rememberMe ? 3600*24*10 : 0; // 10 days
            Yii::app()->user->login($this->_identity,$duration);
            return true;
        }
        else
            return false;
    }
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

如上,假如我把$duration=$this->rememberMe ? 36002410 : 0; // 10 days,即我设置为10天。是cookie的有效期设置为10天,还是cookie和session的有效期都设置为10天呢?
我想把session的有效期设置10天。不知道在哪里可以设置。
还有一个问题,假如cookie是10天,session只有半个小时。第二天我带着cookie登录的时候,是不是PHP根据cookie生成了一个session。
还是php自动生成了session,然后把sessionID重新写回到cookie中间去呢?

session是存在服务器上的,

cookie是存在于客户端上的也就是你自己的电脑,

你浏览器关掉,session就会失效的,

session的有效期有服务器的设置来控制

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage