首页 > 开发 > PHP > 正文

使用无限生命期Session的方法

2024-05-04 22:55:26
字体:
来源:转载
供稿:网友
  • 本文来源于网页设计爱好者web开发社区http://www.html.org.cn收集整理,欢迎访问。
  • 在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”一样的时间;
    设置完毕后,打开编辑器,输入如下的代码:
    ------------------------------------------------------------------------------------
    <?
    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的相关信息(如图1所示)。其中有一项“session.name”的参数(图中已经标出),这个就是我们需要的服务器“session.name”,一般是“phpsessid”。
    记下了sessionid的名称后,我们就可以实现永久的session数据储存了!
    打开编辑器,输入下面的代码:
    ------------------------------------------------------------------------------------
    <?
    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。

    发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表