Php中设置Session超时时间登录时间限制

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

第一种方法即设置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(www.phpfensi.com)(isset($_SESSION['expiretime'])) { 
    if($_SESSION['expiretime'] < time()) { 
        unset($_SESSION['expiretime']); 
        header('Location: logout.php?TIMEOUT'); // 登出 
        exit(0); 
    } else { 
        $_SESSION['expiretime'] = time() + 3600; // 刷新时间戳 
    } 
} 

经验,其实session超时时间php默认就有一会时间了,当然我们可以按上面的方法来设置一下了,这种做法我觉得使用cookies会更方便.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值