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过一分钟后还是不过期,我的测试代码在下面,希望高手指点是什么原因,多谢!
<?PHP
if (isset($_POST['username'])) {
$sess_lim = array("none","nocache","private","private_no_expire","public"); //session_cache_expire(1);
//session_cache_limiter( $sess_lim[2] );
echo "sess_lim:".$sess_lim[2];
session_cache_limiter('private');
session_cache_expire(1);
$cache_expire = session_cache_expire(); session_start();
$_SESSION["username"] = $_POST['username'];
++$_SESSION["count"] ;
echo "<pre>";
print_r($_SESSION);
echo "</pre>";
echo "</ p></ br>";
echo 'sessID:'.session_id(); };
?>
<form action="" method="post">
<input type="text" name="username" value="<?php echo $_SESSION['username']?>">
<input type="submit" name="Submit" value="提交">
</form>
</ br> <?PHP
//phpinfo();
echo "expire:".session_cache_expire()."分钟";
?>
另外,浏览器缓存的工作机理是什么?它对静态或动态的内容是如果管理控制的?