PHP Session会话超时时间设置方法教程

发布时间:2020-08-19编辑:脚本学堂
分享一个严格的PHP Session会话超时时间设置方法,结合两种方法保证超时时间后会话失效,php session实例教程,有需要的朋友参考下。

PHP Session会话超时时间设置教程

PHP项目用到了限制登录时间的功能,比如用户登录系统60分钟后如果没有操作就自动退出。
第一种方法,设置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;。
www.jb200.com)在检查用户登录情况时,使用:
 

复制代码 代码示例:
if(isset($_SESSION['expiretime'])) {
    if($_SESSION['expiretime'] < time()) {
        unset($_SESSION['expiretime']);
        header('Location: logout.php?TIMEOUT'); // 登出
        exit(0);
    } else {
        $_SESSION['expiretime'] = time() + 3600; // 刷新时间戳
    }
}

根据laruence大神的文章《如何设置一个严格30分钟过期的Session》,可以结合第一种和第二种方法来最终决定会话超时时间。

以上通过实例介绍了PHP Session会话超时时间的设置方法,希望对大家有所帮助。