微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

一个严格的PHP Session会话超时时间设置方法

最近某个PHP项目用到了限制登录间的功能,比如用户登录系统60分钟后如果没有操作就自动退出,我搜索了网络收集了有以下方法可供参考。

第一种方法即设置PHP.ini配置文件,设置session.gc_maxlifetime和session.cookie_lifetime节点属性值,当然也可以使用ini_set函数改变当前上下文环境的属性值:

代码如下:

第二种方法即设置Session时间戳,比如下面的办法。

登录成功时设置时间戳为当前时间推后1小时,$_SESSION['expiretime'] = time() + 3600;。在检查用户登录情况使用如下代码
<div class="codetitle"><a style="CURSOR: pointer" data="14719" class="copybut" id="copybut14719" onclick="doCopy('code14719')"> 代码如下:

<div class="codebody" id="code14719">
if(isset($_SESSION['expiretime'])) {
if($_SESSION['expiretime'] < time()) {
unset($_SESSION['expiretime']);
header('Location: logout.PHP?TIMEOUT'); // 登出
exit(0);
} else {
$_SESSION['expiretime'] = time() + 3600; // 刷新时间戳
}
}

根据文章《<a href="//www.jb51.cc/article/52961.htm">//www.jb51.cc/article/52961.htm》,我们可以结合第一种和第二种方法来最终决定会话超时时间。

原文地址:https://www.jb51.cc/php/24550.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐