如果客户端没有禁用 Cookie,则 Cookie 在启动 Session 会话的时候扮演的是存储 Session ID 和 Session 生存期的角色,我们来手动设置 Session 的生存期.
例子,利用cooikes,代码如下:
- <?php
- session_start();
-
- $lifeTime = 24 * 3600;
- setcookie(session_name(), session_id(), time() + $lifeTime, "/");
- ?>
PHP5 Session还提供了一个函数 session_set_cookie_params(); 来设置PHP5 Session的生存期的,该函数必须在 session_start() 函数调用之前调用,代码如下:
- <?php
-
- $lifeTime = 24 * 3600;
- session_set_cookie_params($lifeTime);
- session_start();
- ?>
php中还有一个ini_set可以设置session.gc_maxlifetime来设定Session的生存周期,例如,代码如下:
- <?php
- ini_set('session.gc_maxlifetime', 3600);
- ini_get('session.gc_maxlifetime');
-
- ?>
下面提供一个别人封装好的函数,但是我没有测试过,仅供参考,代码如下:
- <?php
- function start_session($expire = 0)
- {
- if ($expire == 0) {
- $expire = ini_get('session.gc_maxlifetime');
- } else {
- ini_set('session.gc_maxlifetime', $expire);
- }
-
- if (emptyempty($_COOKIE['PHPSESSID'])) {
- session_set_cookie_params($expire);
- session_start();
- } else {
- session_start();
- setcookie('PHPSESSID', session_id(), time() + $expire);
- }
- }
- ?>
使用方法:加入start_session(600);//600秒以后过期. |