Fork me on GitHub

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


我亦只有一个一生,不能慷慨赠予我不爱的人。

设置php.ini配置文件

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

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

设置Session时间戳

第二种方法即设置Session时间戳,比如下面的办法。
在登录成功时设置时间戳为当前时间推后1小时,$_SESSION['expiretime'] = time() + 3600;。在检查用户登录情况使用如下代码:

1
2
3
4
5
6
7
8
9
if(isset($_SESSION['expiretime'])) {
if($_SESSION['expiretime'] < time()) {
unset($_SESSION['expiretime']);
header('Location: logout.php?TIMEOUT'); // 登出
exit(0);
} else {
$_SESSION['expiretime'] = time() + 3600; // 刷新时间戳
}
}

http://wangye.org/blog/archives/933/
http://www.laruence.com/2012/01/10/2469.html

请我喝一个苹果味的美年达吧,谢谢!