欢迎光临
我们一直在努力

使用无限生命期Session的方法-PHP教程,PHP技巧

建站超值云服务器,限时71元/月

本文不敢说非常好,但是笔者相信大多数phper都曾经想过这些问题。

使用无限生命期session的方法

在php4.0中加入了对session的支持,方便了我们很多程序,比如购物车等等!

在很多论坛中,session也用于处理用户的登陆,记录下用户名和密码,使得用户不必每次都输入自己的用户名和密码!但是一般的session的生命期有限,如果用户关闭了浏览器,就不能保存session的变量了!那么怎么样可以实现session的永久生命期呢?

大家知道,session储存在服务器端,根据客户端提供的sessionid来得到这个用户的文件,然后读取文件,取得变量的值,sessionid可以使用客户端的cookie或者http1.1协议的query_string(就是访问的url的“?”后面的部分)来传送给服务器,然后服务器读取session的目录……

要实现session的永久生命期,首先需要了解一下php.ini关于session的相关设置(打开php.ini文件,在“[session]”部分):

1、session.use_cookies:默认的值是“1”,代表sessionid使用cookie来传递,反之就是使用query_string来传递;

2、session.name:这个就是sessionid储存的变量名称,可能是cookie,也可能是query_string来传递,默认值是“phpsessid”;

3、session.cookie_lifetime:这个代表sessionid在客户端cookie储存的时间,默认是0,代表浏览器一关闭sessionid就作废……就是因为这个所以session不能永久使用!

4、session.gc_maxlifetime:这个是session数据在服务器端储存的时间,如果超过这个时间,那么session数据就自动删除!

还有很多的设置,不过和本文相关的就是这些了,下面开始讲使用永久session的原理和步骤。

前面说过,服务器通过sessionid来读取session的数据,但是一般浏览器传送的sessionid在浏览器关闭后就没有了,那么我们只需要人为的设置sessionid并且保存下来,不就可以……

如果你拥有服务器的操作权限,那么设置这个非常非常的简单,只是需要进行如下的步骤:

1、把“session.use_cookies”设置为1,打开cookie储存sessionid,不过默认就是1,一般不用修改;

2、把“session.cookie_lifetime”改为正无穷(当然没有正无穷的参数,不过999999999和正无穷也没有什么区别);

3、把“session.gc_maxlifetime”设置为和“session.cookie_lifetime”一样的时间;

设置完毕后,打开编辑器,输入如下的代码:

<?php

session_start();

session_register(count);

$count++;

echo $count;

?>

然后保存为“session_check.php”,用浏览器打开“session_check.php”,看看显示的是不是“1”,再关闭浏览器,然后再打开浏览器访问“session_check.php”,如果显示“2”,那么恭喜了,你已经成功;如果失败的话,请检查你前面的设置。

但是如果你没有服务器的操作权限,那就比较麻烦了,你需要通过php程序改写sessionid来实现永久的session数据保存。查查php.net的函数手册,可以见到有“session_id”这个函数:如果没有设置参数,那么将返回当前的sessionid,如果设置了参数,就会将当前的sessionid设置为给出的值……

只要利用永久性的cookie加上“session_id”函数,就可以实现永久session数据保存了!

但是为了方便,我们需要知道服务器设置的“session.name”,但是一般用户都没有权限查看服务器的php.ini设置,不过php提供了一个非常好的函数“phpinfo”,利用这个可以查看几乎所有的php信息!

<title>php相关信息显示</title>

<?phpinfo()?>

打开编辑器,输入上面的代码,然后在浏览器中运行这个程序,会见到php的相关信息(如图示)。其中有一项“session.name”的参数(图中已经标出),这个就是我们需要的服务器“session.name”,一般是“phpsessid”。

记下了sessionid的名称后,我们就可以实现永久的session数据储存了!

打开编辑器,输入下面的代码: <?php

session_start(); // 启动session

session_register(count); // 注册session变量count

if(isset($phpsessid)) {

session_id($phpsessid);

} // 如果设置了$phpsessid,就将sessionid赋值为$phpsessid,否则生成sessionid

$phpsessid = session_id(); // 取得当前的sessionid

$count++; // 变量count加1

setcookie(phpsessid, $phpsessid, time()+3156000); // 储存sessionid到cookie中

echo $count; // 显示session变量count的值

?>

保存之后,利用和刚才拥有服务器权限时候的检测一样的方法,检测是否成功的保存了sessionid。

后记:

其实真正的永久储存是不可能的,因为cookie的保存时间有限,而服务器的空间也有限……但是对于一些需要保存时间比较长的站点,以上方法就已经足够了!关于session的其他应用,可以参见zphp.com的文章。

最后,笔者的调试环境:windows98digext(se)+apache+php 4.04。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 使用无限生命期Session的方法-PHP教程,PHP技巧
分享到: 更多 (0)