php登陆过期时间,php如何设置过期时间的session

php设置过期时间的session方法:首先使用memcache或Redis来保存session,设置过期时间;然后创建一个session类,在session写入时,把过期时间也写入;最后读取时,根据过期时间判断是否已过期即可。

14c3ee884ca286f2b5c2e32a8afbc8d8.png

php设置过期时间的session方法:

一、php session 有效期

PHP的session有效期默认是1440秒(24分钟),如果客户端超过24分钟没有刷新,当前session会被回收,失效。

当用户关闭浏览器,会话结束,session也会失效。

可以修改php.ini的session.gc_maxlifetime来设置session的生命周期,但并不能保证在超过这一时间后session信息立即会删除。因为GC是按机率启动的,可能在某一个长时间内都没有被启动。那么大量的session在超过session.gc_maxlifetime后仍然有效。

二、.session.gc_maxlifetime,session.gc_probability,session.gc_divisor说明

session.gc_maxlifetime = 30 表示当session文件在30秒后没有被访问,则视为过期session,等待GC回收。

GC进程调用的概率是通过session.gc_probability/session.gc_divisor计算得来的,而session.gc_divisor默认是1000,

如果session.gc_probability = 1000,那么GC进程在每次执行session_start()时都会调用,执行回收。

把session.gc_probability/session.gc_divisor的机率提高,会有帮助,但会对性能造成严重影响。

三、严格控制session过期方法

1、使用memcache/Redis来保存session,设置过期时间,因为memcache/redis的回收机制不是按机率的,可以确保session过期后失效。

2、只使用php实现,创建一个session类,在session写入时,把过期时间也写入。读取时,根据过期时间判断是否已过期。<?php

/**

* Session控制类

*/

class Session{

/**

* 设置session

* @param String $name session name

* @param Mixed $data session data

* @param Int $expire 超时时间(秒)

*/

public static function set($name, $data, $expire=600){

$session_data = array();

$session_data['data'] = $data;

$session_data['expire'] = time()+$expire;

$_SESSION[$name] = $session_data;

}

/**

* 读取session

* @param String $name session name

* @return Mixed

*/

public static function get($name){

if(isset($_SESSION[$name])){

if($_SESSION[$name]['expire']>time()){

return $_SESSION[$name]['data'];

}else{

self::clear($name);

}

}

return false;

}

/**

* 清除session

* @param String $name session name

*/

private static function clear($name){

unset($_SESSION[$name]);

}

}

?>

demo:<?php

session_start();

$data = '123456';

session::set('test', $data, 10);

echo session::get('test'); // 未过期,输出

sleep(10);

echo session::get('test'); // 已过期

?>相关免费推荐:编程视频课程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值