关于session_cache_expire 的理解

来源:百度文库 编辑:神马文学网 时间:2024/06/13 05:49:58
关于session_cache_expire 的理解
【编辑:C1GStudio.com】
session_cache_limiter,它是session在客户端的缓存方式,有nocache,private,private_no_expire,publice主这几种。

cache是属于浏览器的特性,它决定你浏览网页的缓存方式,没有缓存的情况会使你按浏览的“后退”键时提示要你更新连接,之前的内容就没有了,比如你填入的表单信息,都被丢失。
通过header("Cache-Control: no-store, no-cache, must-revalidate");函数也一样达到效果。

然而,session的处理机制里,就强制自动调用了header函数设置cache,这个置就由php.ini中的缺省值session.cache_limiter值或由session_cache_limiter函数设定所取代。

session_cache_limiter内的几个参数意义是:
nocache:当然是不缓存(比如:表单信息被清除),但公共变量可以缓存
private:私有方式缓存(比如:表单信息被保留,但在生存期内有效)
private_no_cache:私有方式但不过期(表单信息被保留)
publice:公有方式,(表单信息也被保留)

它们之间的具体区别,我还不是太清楚,可以区别的是除nocache外其它的都可以缓存,private方式还受生存期影响,这个生存期应该是由session.cache_expire给定,它在php.ini中设置或session_cache_expire函数设置,缺省是180分钟。

不过,我做过试验,设置session.cache_expire置为1分钟,但实际情况不起作用,cache过一分钟后还是不过期,我的测试代码在下面,希望高手指点是什么原因,多谢!

if (isset($_POST['username'])) {
$sess_lim = array("none","nocache","private","private_no_expire","public");

session_cache_expire(1);
session_cache_limiter( $sess_lim[2] );

session_start();
$_SESSION["username"] = $_POST['username'];
++$_SESSION["count"] ;
echo "
";
print_r($_SESSION);
echo "
";
echo "";
echo 'sessID:'.session_id();

};
?>






//phpinfo();
echo "expire:".session_cache_expire()."分钟";
?>

另外,浏览器缓存的工作机理是什么?它对静态或动态的内容是如果管理控制的?