• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

session时间设立

php 搞代码 4年前 (2022-01-24) 21次浏览 已收录 0个评论

session时间设置

本帖最后由 guliputaoyou 于 2013-04-23 11:04:18 编辑

由于我无法更改服务器配置文件,但是需要修改保持用户登录的时间为2h。
于是我p本@文来源[email protected]搞@^&代*@码网(搞代gaodaima码hpinfo了一下发现gc_maxlifetime=1440,
于是查了很多资料,将此函数用在登录的页面上了,用来代替原本的session_start()。
function start_session_custom($expire = 36000)
{
ini_set(‘session.gc_maxlifetime’, $expire);

if (empty($_COOKIE[‘PHPSESSID’])) {
session_set_cookie_params($expire);
session_start();
} else {
session_start();
setcookie(‘PHPSESSID’, session_id(), time()+ $expire);
}
}
尽管将$expire设为36000(10h),可是仍然不起作用。
另:一堆老代码里竟然有很多个session_start,莫非要所有的都替换为start_session_custom?
我只在第一个session_start的页面(也就是登录页面)改莫非就不行?

更正一下:
全文查了一下 发现居然有session_set_save_handler
其中
而$maxlifetime=72000;
function gc($maxlifetime)
{
if(rand(0,1000)%1000!=0)return false;
$expiretime = $this->now – $maxlifetime;
return $this->db->query(“DELETE FROM $this->table WHERE `last_activity`<$expiretime");

}

——解决方案——————–
原则是:在 session_start 之前设置,否则无效

你可以将你的这段代码放入公共文件(所有的程序都会加载他的那种),而删去其他文件中的 session_start
如果你觉得查找起来比较麻烦,那么你可以在 php 5.4 环境中运行一下你的项目
php 5.4 会对重复出现的 session_start 发出警告,据此修改起来就很方便了


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:session时间设立
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址