详解php设置session(过期、失效、有效期)

1,344次阅读
没有评论

在 php 中设置 session 有很多方面包有给 session 设置值或直接设置过期、失效和有效期,下面小编来给大家给各位朋友介绍怎么使用。

我们先来看看在 php.ini 中 session 怎么设置,打开 php.ini,查找 Session 设置部分中以下一项,代码如下:

session.save_path = "N;/path"
session.save_path = "C:/Temp"  #此处以你自己设定的路径为准 

  这项设置提供给我们可以给 session 存放目录进行多级散列,其中“N”表示要设置的目录级数,后面的“/path”表示 session 文件存放的根目录路径,比如我们设置为下面的格式,代码如下:

session.save_path = "2;C:/Temp"

上面的设置表示我们把 php 的 session 文件进行两级目录存储,每一级目录分别是 0 - 9 和 a - z 共 36 个字母数字为目录名,这样存放 session 的目录可以达到 36*36 个,共 1332 个文件夹,相信作为单台服务器来说,这是完全够用了,如果说您的系统架构设计为多台服务器共享 session 数据,可以把目录级增加到 3 级或者更多。

Session 过期时间设定

继续 PHP 中的 Session 话题,在 PHP 中主要通过设置 session.gc_maxlifetime 来设定 Session 的生存周期, 例如如下代码:

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

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

<?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 秒以后过期。

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 的值 
?>

以上就是 php 设置 session 的具体做法,内容涉及 session 设置值或直接设置过期、失效和有效期,希望对大家的学习有所帮助。

正文完
 0
飞翔的mouse
版权声明:本站原创文章,由 飞翔的mouse 于2019-09-08发表,共计2000字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。