请问php中session的超时时间问题

WBOY
Release: 2016-06-23 13:53:57
Original
849 people have browsed it

新手初学php,许多不了解的地方求教。以前学过asp,知道有个session.timeout可以设置超时时间,默认是20分钟。 但PHP里面没有找到类似设置会话超时时间的函数,不知如果php页面不刷新也就是对服务器端没有任何请求的情况下默认多久会话会超时失效?

在php.ini中有个session.cookie_lifetime 默认是0, 这个0和会话超时时间有关吗?0是不是代表只要浏览器不关闭,session就一直有效,不会超时?
另外,配置文件里还有个session.gc_maxlifetime = 1440,这个查手册是垃圾回收删除默认tmp目录下sess文件的超时时间,这个默认的1440秒也就是24分钟是会话超时时间吗?24分钟后,sess文件有可能被删除,那么意味着会话也失效了?可这个删除有个概率,默认1/1000,也就是很大可能没有删除,那如果没删除session就一直有效不会超时么? 也就是24分钟没刷新 会话也不一定就会超时失效吗?

求解。


回复讨论(解决方案)

session.gc_maxlifetime 不是针对 session 有效时间的,而是针对垃圾回收进程 gc 的
他告知 gc 进程,可以删除 session.gc_maxlifetime 秒之前修改过的临时文件

当然,只要 sessionid 对应的临时文件存在,则 session 就有效

要想自主控制 session 的行为,则需要自己编写处理代码。手册或网上的示例代码只是演示了基本写法,你需要根据你的需求进行扩展

session的超时时间并不是很准的。
如果需要很准,则在session中记录过期时间,当session文件不存在,或存在但过期时间超时,则当失败。

if(isset($_SESSION['name'])){    if($_SESSION['name']['expire']>time()){       echo 'session 未过期';   }else{       echo 'session 未过期';   }}else{    echo 'session 过期';}
Copy after login

谢谢,大致了解了
楼上的
if($_SESSION['name']['expire']>time()){
       echo 'session 未过期';
   }
应该是echo 'session 已过期'; 吧

感觉php里面没有确定的默认会话超时时间,如果想控制用户会话超时时间,需要自己编程控制的

if($_SESSION['name']['expire']>time()){
       echo 'session 未过期';
   }

?期??比?在小才?期啊,比?在大怎???期呢?
明天?于今天??是?期?不?吧。

哦,理解有误,按照上面理解的话,那么
if($_SESSION['name']['expire']>time()){
       echo 'session 未过期';
   }else{
       echo 'session 未过期';  
   }

else{
       echo 'session 未过期';-----是不是应该改为 echo 'session 已过期'; ?
   }

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template