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

 2025-01-16  阅读 212  评论 8  点赞 101

摘要:最近某个php项目用到了限制登录时间的功能,比如用户登录系统60分钟后如果没有操作就自动退出,我搜索了网络收集了有以下方法可供参考。 第一种方法即设置php.ini配置文件,设置session.gc_maxlifetime和session.cookie_lifetime节点属性值,当然也可以使用ini_set函数改变当

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

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

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

复制代码 代码如下:

ini_set('session.gc_maxlifetime', "3600"); // 秒
ini_set("session.cookie_lifetime","3600"); // 秒


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

在登录成功时设置时间戳为当前时间推后1小时,$_session['expiretime'] = time() + 3600;。在检查用户登录情况使用如下代码:
复制代码 代码如下:

if(isset($_session['expiretime'])) {
    if($_session['expiretime'] < time()) {
        unset($_session['expiretime']);
        header('location: logout.php?timeout'); // 登出
        exit(0);
    } else {
        $_session['expiretime'] = time() + 3600; // 刷新时间戳
    }
}

根据文章《http://www.jb51.net/article/52961.htm》,我们可以结合第一种和第二种方法来最终决定会话超时时间。


标签:phpphp教程

评论列表:

  •   echo111
     发布于 2天前回复该评论
  • 写的很不错,学到了!
显示更多评论

发表评论:

管理员

承接各种程序开发,外贸网站代运营,外贸网站建设等项目
  • 内容2460
  • 积分67666
  • 金币86666

Copyright © 2024 LS'Blog-保定PHP程序员老宋个人博客 Inc. 保留所有权利。 Powered by LS'blog 3.0.3

页面耗时0.0272秒, 内存占用1.94 MB, 访问数据库29次

冀ICP备19034377号