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

如果客户端没有禁用 Cookie,则 Cookie 在启动 Session 会话的时候扮演的是存储 Session ID 和 Session 生存期的角色,我们来手动设置 Session 的生存期.

例子,利用cooikes,代码如下:

  1. <?php
  2. session_start();
  3. // 保存一天
  4. $lifeTime = 24 * 3600;
  5. setcookie(session_name(), session_id(), time() + $lifeTime, "/");
  6. ?>

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

  1. <?php
  2. // 保存一天 www.phpfensi.com
  3. $lifeTime = 24 * 3600;
  4. session_set_cookie_params($lifeTime);
  5. session_start();
  6. ?>

php中还有一个ini_set可以设置session.gc_maxlifetime来设定Session的生存周期,例如,代码如下:

  1. <?php
  2. ini_set('session.gc_maxlifetime', 3600); //设置时间
  3. ini_get('session.gc_maxlifetime');//得到ini中设定值
  4. ?>

下面提供一个别人封装好的函数,但是我没有测试过,仅供参考,代码如下:

  1. <?php
  2. function start_session($expire = 0)
  3. {
  4. if ($expire == 0) {
  5. $expire = ini_get('session.gc_maxlifetime');
  6. } else {
  7. ini_set('session.gc_maxlifetime', $expire);
  8. }
  9. if (emptyempty($_COOKIE['PHPSESSID'])) {
  10. session_set_cookie_params($expire);
  11. session_start();
  12. } else {
  13. session_start();
  14. setcookie('PHPSESSID', session_id(), time() + $expire);
  15. }
  16. }
  17. ?>

使用方法:加入start_session(600);//600秒以后过期.