session有效期问题

在PHP中Session的有效期默认为24分钟,所以PHP提供了session_set_cookie_params 函数来修改其有效时间.
然而在绝大部分情况下,光是用此函数是无效的.

主要原因是因为PHP默认将session文件放置在统一的目录下,按php.ini设置的时间进行GC(垃圾清理).即使你在PHP中通过函数动态的将清理时间延长,但在程序执行完成后,设置就会失效.

这个时候GC程序就会把你的session按照php.ini设置的时间进行清理.

解决的办法是通过 session_set_save_handler 函数将本应用的session移至独立目录,这样就不会被GC清理掉了.

session_set_cookie_params( 60*60*24*3 );
session_save_path( ROOT .’session/’ );
session_start();

转载于:https://my.oschina.net/tenking/blog/28579

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值