关于session的几个补充函数
在PHP下,关于session的讨论很多,其实在PHP4中还有几个函数是我们平时没有注意到的。 下面我把它们介绍给大家吧。 其中的session_set_save_handler()可真是个好东西。 //******************** session_unset (PHP4 >= 4.0b4) void session_unset(void); 这个函数可以把当然注册的所有的session变量置为空。注意它不是unregister,也不同于destroy。 下面这个例子,对此函数做了很好的说明。 <?php session_register(''a'',''b'',''c''); //auto-session-start $a=1; $b=2; $c=3; session_unregister(''a''); //unregistrered $a echo "A: $a - reg:".session_is_registered(''a'')." "; // but the global $a remains session_unset(); // unsets $b und $c echo "B:$b - reg:".session_is_registered(''b'')." "; // the registration remains ! echo "C:$c - reg:".session_is_registered(''c'')." "; echo session_encode(); ?> 输出: A: 1 - reg: B: - reg:1 C: - reg:1 !b|!c| //******************************** session_get_cookie_params (PHP4 >= 4.0RC2) array session_get_cookie_params (void); 返回一个数组,记录了当前session的cookie的一些信息。 有: "lifetime" - cookie的生存期。 "path" - cookie的保存路径。 "domain" - cookie的域。 //******************************* session_set_cookie_params (PHP4 >= 4.0b4) void session_set_cookie_params (int lifetime [, string path [, string domain]]) 设置session的cookie的一些参参数,类似于php.ini中的设置,但本函数所作的设置,只对当前脚本文件有效。 //******************************* 下面要介绍的这个函数应是对大家都很有用的,你是不是对自定义一个不用cookie来保存的session有兴趣呢?这个函数就可以实现你这样的设想。 让我想想,如果不用cookie的好处是什么?至少一点,你不用担心客户端的的cookie的功能是否打开了,对吧。 session_set_save_handler (PHP4 >= 4.0b4) void session_set_save_handler (string open, string close, string read, string write, string destroy, string gc) 这个函数可以定义用户级的session的保存函数(打开、关闭、写入等)。 比如,我们想把session保存在本地的一个数据库中时,本函数就很有用了。 !!!注意:使用本函数前,先要配置php.ini文件,session.save_hadler=user ,否则,session_set_save_handler()不会生效。 此外,根据我的测试,你如果想让这样的session跨页面使用,还要在每一个用到session的脚本文件中加入你自定的函数及session_set_save_handler,所以,最好的方法是做成一个单独的文件,在每一个要用到session的脚本中用include来包含进来。 下面这个例子提供了一个最基本的session保存法,类似于默认的files方法。 如果你想用数据库来实现,这也是很容易做到的。 Example 1. session_set_save_handler() example <?php function |
查看所有评论
