作者:寒时凝结公寓_264 | 来源:互联网 | 2018-05-23 22:55
1.在YII的loginForm中间,有一个login方法用来设置记住用户名的时间:{代码...}如上,假如我把$duration$this->rememberMe?36002410:0;10days,即我设置为10天。是cookie的有效期设置为10天,还是...
1.在YII的loginForm中间,有一个login方法用来设置记住用户名的时间:
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;
}
}
如上,假如我把$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方法用来设置记住用户名的时间:
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;
}
}
如上,假如我把$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的有效期有服务器的设置来控制