欢迎光临
我们一直在努力

关于session的几个补充函数-PHP教程,PHP应用

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

在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 open ($save_path, $session_name) {

global $sess_save_path, $sess_session_name;

$sess_save_path = $save_path;

$sess_session_name = $session_name;

return(true);

}

function close() {

return(true);

}

function read ($id) {

global $sess_save_path, $sess_session_name;

$sess_file = "$sess_save_path/sess_$id";

if ($fp = @fopen($sess_file, "r")) {

$sess_data = fread($fp, filesize($sess_file));

return($sess_data);

} else {

return("");

}

}

function write ($id, $sess_data) {

global $sess_save_path, $sess_session_name;

$sess_file = "$sess_save_path/sess_$id";

if ($fp = @fopen($sess_file, "w")) {

return(fwrite($fp, $sess_data));

} else {

return(false);

}

}

function destroy ($id) {

global $sess_save_path, $sess_session_name;

$sess_file = "$sess_save_path/sess_$id";

return(@unlink($sess_file));

}

/*********************************************

* warning – you will need to implement some *

* sort of garbage collection routine here. *

*********************************************/

function gc ($maxlifetime) {

return true;

}

session_set_save_handler ("open", "close", "read", "write", "destroy", "gc");

session_start();

// proceed to use sessions normally

// 现在你就可以象往常一样地使用session了。

?>

//***************************************

session_cache_limiter (php4 cvs only)

string session_cache_limiter ([string cache_limiter])

本函数可以设置或取得session.cache_limiter的值。

在php.ini中也可以做同样的设置。其值有 nocache,public,private。

本函数是通过http的header发送到客户端的。如果为nocache,将禁止任何客户端的cache。而public将允许cache,但是private相对public而言,更为安全一点。

缺省值是在php.ini中的设置,如果你要使用它,必须在每次调用session_start()之前调用本函数。

此函数现在只能在cvs模式下运行,但是php4.0.3将支持它。

example 1. session_cache_limiter() examples

<?php

# set the cache limiter to private

session_cache_limiter(private);

$cache_limiter = session_cache_limiter();

echo "the cache limiter is now set to $cache_limiter<p>";

?>

//*****************************

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

相关推荐

  • 暂无文章