php如何修改SESSION的生存存储时间的实例代码


Posted in PHP onJuly 05, 2017

如何修改SESSION的生存时间

我们来手动设置 Session 的生存期:

<?php
session_start(); 
// 保存一天 
$lifeTime = 24 * 3600; 
setcookie(session_name(), session_id(), time() + $lifeTime, "/"); 
?>

其实 Session 还提供了一个函数 session_set_cookie_params(); 来设置 Session 的生存期的,该函数必须在 session_start() 函数调用之前调用:

<?php 
// 保存一天 
$lifeTime = 24 * 3600; 
session_set_cookie_params($lifeTime); 
session_start();
$_SESSION["admin"] = true; 
?>

如果客户端使用 IE 6.0 , session_set_cookie_params(); 函数设置 Cookie 会有些问题,所以我们还是手动调用 setcookie 函数来创建 cookie。

php中session过期时间设置

网上很多人给出了解答:修改php配置文件中的session.gc_maxlifetime。如果想了解更多session回收机制,继续阅读。(本文环境php5.2)

概述:每一次php请求,会有1/100的概率(默认值)触发“session回收”。如果“session回收”发生,那就会检查/tmp/sess_*的文件,如果最后的修改时间到现在超过了1440秒(gc_maxlifetime的值),就将其删除,意味着这些session过期失效。

1. session在server端(一般是Apache with PHP module)如何存在的?

默认的,php会将session保存在/tmp目录下,文件名为这个样子:sess_01aab840166fd1dc253e3b4a3f0b8381。每一个文件对应了一个session(会话)。

more /tmp/sess_01aab840166fd1dc253e3b4a3f0b8381

username|s:9:”jiangfeng”;admin|s:1:”0″;

#变量名|类型:长度:值

删除这里的session文件,就表示对应的session失效了。

2. session在client端(一般是浏览器)如何存在的?

session在浏览器端,只需要保存session ID(由server端生成的唯一ID)就可以了。有两种保存方式:在cookie中、在url里面。如果cookie中保存session ID,就可以看到浏览器的cookie中有一个PHPSESID变量。如果是URL传递的,就可以看到形如:
index.php?PHPSESID=01aab840166fd1dc253e3b4a3f0b8381的URL。(在server端通过session.use_cookies来控制使用哪一种方式)

3. 在server端,php如何判断session文件是否过期?

如果”最后的修改时间”到”现在”超过了gc_maxlifetime(默认是1440)秒,这个session文件就被认为是过期了,在下一次session回收的时候,如果这个文件仍然没有被更改过,这个session文件就会被删除(session就过期了)。

简单的说,如果我登录到某网站,如果在1440秒(默认值)内没有操作过,那么对应的session就认为是过期了。

所以,修改php.ini文件中的gc_maxlifetime变量就可以延长session的过期时间了:(例如,我们把过期时间修改为86400秒)

session.gc_maxlifetime = 86400

然后,重启你的web服务(一般是apache)就可以了。

注意:php5里面session过期使用了回收机制。这里设置时间为86400秒,如果session在86400秒内没有被修改过,那么在下一次“回收”时才真的被删除。

3. session“回收”何时发生?

默认情况下,每一次php请求,就会有1/100的概率发生回收,所以可能简单的理解为“每100次php请求就有一次回收发生”。这个概率是通过以下参数控制的

#概率是gc_probability/gc_divisor
session.gc_probability = 1
session.gc_divisor = 100

注意1:假设这种情况gc_maxlifetime=120,如果某个session文件最后修改时间是120秒之前,那么在下一次回收(1/100的概率)发生前,这个session仍然是有效的。

注意2:如果你的session使用session.save_path中使用别的地方保存session,session回收机制有可能不会自动处理过期session文件。这时需要定时手动(或者crontab)的删除过期的session:cd /path/to/sessions; find -cmin +24 | xargs rm

4. 一些特殊情况

因为回收机制会检查文件的“最后修改时间”,所以如果某个会话是活跃的,但是session的内容没有改变过,那么对应的session文件也就没有改变过,回收机制会认为这是一个长时间没有活跃的session而将其删除。这是我们不愿看到的,可以通过增加如下的简单代码解决这个问题:

<?php
if(!isset($_SESSION['last_access'])||(time()-$_SESSION['last_access'])>60)
 $_SESSION['last_access'] = time();
?>

代码会每隔60秒,尝试修改修改一次session。

总结:如果想修改session过期时间,修改变量gc_maxlifetime就可以了。php5的session采用被动的回收机制(garbage collection)。过期的session文件不会自己消失,而是通过触发“回收”来处理过期的session。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
社区(php&amp;&amp;mysql)二
Oct 09 PHP
PHP Pear 安装及使用
Mar 19 PHP
php操作excel文件 基于phpexcel
Jul 02 PHP
php中flush()、ob_flush()、ob_end_flush()的区别介绍
Feb 17 PHP
php用header函数实现301跳转代码实例
Nov 25 PHP
PHP检测移动设备类mobile detection使用实例
Apr 14 PHP
php中mysql连接和基本操作代码(快速测试使用,简单方便)
Apr 25 PHP
php实现cookie加密的方法
Mar 10 PHP
php不使用copy()函数复制文件的方法
Mar 13 PHP
yii2整合百度编辑器umeditor及umeditor图片上传问题的解决办法
Apr 20 PHP
Zend Framework过滤器Zend_Filter用法详解
Dec 09 PHP
ThinkPHP5.1的权限控制怎么写?分享一个AUTH权限控制
Mar 09 PHP
PHP实现根据密码长度显示安全条
Jul 04 #PHP
PHP截取发动短信内容的方法
Jul 04 #PHP
phpcms配置列表页以及获得文章发布时间
Jul 04 #PHP
一个非常实用的php文件上传类
Jul 04 #PHP
php基于数组函数实现关联表的编辑操作示例
Jul 04 #PHP
PHP基于方差和标准差计算学生成绩的稳定性示例
Jul 04 #PHP
PHP处理bmp格式图片的方法分析
Jul 04 #PHP
You might like
php json_encode()函数返回json数据实例代码
2014/10/10 PHP
php投票系统之增加与删除投票(管理员篇)
2016/07/01 PHP
php的laravel框架快速集成微信登录的方法
2016/12/12 PHP
PHP简单读取xml文件的方法示例
2017/04/20 PHP
php面向对象程序设计中self与static的区别分析
2019/05/21 PHP
jquery $.ajax入门应用一
2008/11/19 Javascript
JavaScript读取中文cookie时的乱码问题的解决方法
2009/10/14 Javascript
Javascript将string类型转换int类型
2010/12/09 Javascript
javascript数组遍历for与for in区别详解
2014/12/04 Javascript
json的使用小结
2016/06/08 Javascript
关于Sequelize连接查询时inlude中model和association的区别详解
2017/02/27 Javascript
详解Vuejs2.0之异步跨域请求
2017/04/20 Javascript
Vue.js项目中管理每个页面的头部标签的两种方法
2018/06/25 Javascript
jQuery选择器之层次选择器用法实例分析
2019/02/19 jQuery
详解js 创建对象的几种方法
2019/03/08 Javascript
Vue+axios+WebApi+NPOI导出Excel文件实例方法
2019/06/05 Javascript
jQuery插件实现图片轮播效果
2020/10/19 jQuery
[56:35]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第一局
2016/03/06 DOTA
Python的净值数据接口调用示例分享
2016/03/15 Python
python安装教程 Pycharm安装详细教程
2017/05/02 Python
通过Python实现自动填写调查问卷
2017/09/06 Python
python实现二叉查找树实例代码
2018/02/08 Python
python 实现aes256加密
2020/11/27 Python
基于css3 animate制作绚丽的动画效果
2015/11/24 HTML / CSS
详解px单位html5响应式方案
2018/03/08 HTML / CSS
欧缇丽英国官方网站:Caudalie英国
2016/08/17 全球购物
求职简历的自我评价怎样写好
2013/10/07 职场文书
蛋糕店的商业计划书范文
2014/01/27 职场文书
人力管理专业毕业生求职信
2014/02/27 职场文书
小学阳光体育活动总结
2014/07/05 职场文书
基层党员对照检查材料
2014/08/25 职场文书
督导岗位职责范本
2015/04/10 职场文书
检察院起诉意见书
2015/05/20 职场文书
火烧圆明园的观后感
2015/06/03 职场文书
复制别人的成功真的会成功吗?
2019/10/17 职场文书
python元组打包和解包过程详解
2021/08/02 Python