PHP设置会话(Session)超时过期时间实现登录时间限制

来源:互联网 发布:网页游戏自动挂机软件 编辑:程序博客网 时间:2024/05/16 11:32

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

第一种方法即设置php.ini配置文件,设置session.gc_maxlifetimesession.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; // 刷新时间戳    }}

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

转载地址:http://wangye.org/blog/archives/933/

0 0
原创粉丝点击