PHP中的session永不过期的解决思路及实现方法分享
2023-06-13 09:14:27 时间
我们前期开发了一个只有公司客服人员才能使用的系统——有限的几个客服人员。就是这有限的几个客服人员前几天突然就提出这样的问题:我们每隔很短一段时间(半个小时不操作页面),正着急解决客户问题的时候,系统却提示需要登录,耽误了客户的时间……这很不爽!
客户就是上帝,唯一的上帝。于是上峰要求我们能够实现PHP中的session永不过期,除非我们的客服人员人为的让他过期了。出于安全性的考虑我很不理解这种永不过期的行为;出于懒惰的原因我真的不想修改以前的程序。但是没有办法,我依然需要改。
不修改程序是最好的方法了,因为如果修改程序,测试部一定非常郁闷像我一样,那么只能修改系统环境配置,其实很简单,打开php.ini设置文件,修改三行如下:
1、session.use_cookies
把这个的值设置为1,利用cookie来传递sessionid
2、session.cookie_lifetime
这个代表SessionID在客户端Cookie储存的时间,默认是0,代表浏览器一关闭SessionID就作废……就是因为这个所以PHP的session不能永久使用!那么我们把它设置为一个我们认为很大的数字吧,999999999怎么样,可以的!就这样。
3、session.gc_maxlifetime
这个是Session数据在服务器端储存的时间,如果超过这个时间,那么Session数据就自动删除!那么我们也把它设置为99999999。
就这样一切ok了,当然你不相信的话就测试一下看看——设置一个session值过个10天半个月的回来看看,如果你的电脑没有断电或者宕机,你仍然可以看见这个sessionid。
当然也可能你没有控制服务器的权限并不能像我一样幸运的可以修改php.ini设置,一切依靠我们自己也是有办法的,当然就必须利用到客户端存储cookie了,吧得到的sessionID存储到客户端的cookie里面,设置这个cookie的值,然后把这个值传递给session_id()这个函数,具体做法如下:
复制代码代码如下:
客户就是上帝,唯一的上帝。于是上峰要求我们能够实现PHP中的session永不过期,除非我们的客服人员人为的让他过期了。出于安全性的考虑我很不理解这种永不过期的行为;出于懒惰的原因我真的不想修改以前的程序。但是没有办法,我依然需要改。
不修改程序是最好的方法了,因为如果修改程序,测试部一定非常郁闷像我一样,那么只能修改系统环境配置,其实很简单,打开php.ini设置文件,修改三行如下:
1、session.use_cookies
把这个的值设置为1,利用cookie来传递sessionid
2、session.cookie_lifetime
这个代表SessionID在客户端Cookie储存的时间,默认是0,代表浏览器一关闭SessionID就作废……就是因为这个所以PHP的session不能永久使用!那么我们把它设置为一个我们认为很大的数字吧,999999999怎么样,可以的!就这样。
3、session.gc_maxlifetime
这个是Session数据在服务器端储存的时间,如果超过这个时间,那么Session数据就自动删除!那么我们也把它设置为99999999。
就这样一切ok了,当然你不相信的话就测试一下看看——设置一个session值过个10天半个月的回来看看,如果你的电脑没有断电或者宕机,你仍然可以看见这个sessionid。
当然也可能你没有控制服务器的权限并不能像我一样幸运的可以修改php.ini设置,一切依靠我们自己也是有办法的,当然就必须利用到客户端存储cookie了,吧得到的sessionID存储到客户端的cookie里面,设置这个cookie的值,然后把这个值传递给session_id()这个函数,具体做法如下:
<?php
session_start();//启动Session
$_SESSION["count"];//注册Session变量Count
isset($PHPSESSID)?session_id($PHPSESSID):$PHPSESSID=session_id();
//如果设置了$PHPSESSID,就将SessionID赋值为$PHPSESSID,否则生成SessionID
$_SESSION["count"]++;//变量count加1
setcookie("PHPSESSID",$PHPSESSID,time()+3156000);//储存SessionID到Cookie中
echo$count;//显示Session变量count的值
?>
如果很久以后(多久?你自己看吧)你回来刷新这个页面,输出的数字比你走的时候大了1那就对了!如果大了很多,估计是谁动你电脑了,这次测试就不准确了,呵呵……重新出去一会儿吧!
注意:在setcookie一行中的"PHPSESSID"并不是一定的,如果你遇到有个患有修改狂疾病的网管员,他可能对其做了修改,最好的方法是用phpinfo()这个函数看看,确认一下session.name一项的值,比较科学。
相关文章
- PHP常见面试题_php面试常问面试题
- php替换字符串中,PHP 替换字符串中的一些字符方法介绍
- 命令在PHP中执行Linux命令的方法(php执行linux)
- PHP编译MySQL:一步一步指南(php编译mysql)
- 数据库远程连接MySQL数据库:利用PHP实现简易方法(php远程mysql)
- 使用PHP和MySQL精心构建表单(php表单mysql)
- 使用 PHP 查询 MySQL 数据库的方法详解(php查询mysql数据)
- PHP在Linux中的路径指引(php路径linux)
- PHP读取Linux文件的方法(php读取linux文件)
- PHP无法连接MSSQL数据库问题的解决方法(php 无法 mssql)
- PHP环境搭建:从编译MSSQL说起(php 编译mssql)
- PHP管理MSSQL的方法探索(Php管理mssql)
- PHP连接MSSQL:让你更快更好地实现数据互通(php接mssql)
- PHP如何支持使用MS SQL 进行数据库操作(php怎么还用mssql)
- PHP与MSSQL的良好配合,助力数据应用升级(php_mssql)
- 基于PHP和MSSQL的连接设置(php mssql设置)
- 安装MongoDB,接入PHP开发新篇章(php安装mongodb)
- Linux查看PHP版本的方法简介(linux查看php版本)
- 基于Oracle和PHP的新一代组件全面上线(oracle php组件)
- 不重新编译PHP为php增加openssl模块的方法
- PHP和Mysqlweb应用开发核心技术第1部分Php基础-1开始了解php
- php去除换行符的方法小结(PHP_EOL变量的使用)
- php另类上传图片的方法(PHP用Socket上传图片)
- 图解找出PHP配置文件php.ini的路径的方法
- 使用php方法curl抓取AJAX异步内容思路分析及代码分享