|
动态网页技术PHP关于cookie和session的分析(3) <a href="p.php?<?php print session_name() ?>=<?php print session_id() ?>">xxx</a>,也可以通过POST来传递session值.
2.2 session基本用法实例
<?php // page1.php session_start(); echo 'Welcome to page #1'; /* 创建session变量并给session变量赋值 */ $_SESSION['favcolor'] = 'green'; $_SESSION['animal'] = 'cat'; $_SESSION['time'] = time(); // 如果客户端使用cookie,可直接传递session到page2.php echo '<br /><a href="page2.php">page 2</a>'; // 如果客户端禁用cookie echo '<br /><a href="page2.php?' . SID . '">page 2</a>'; /* 默认php5.2.1下,SID只有在cookie被写入的同时才会有值,如果该session 对应的cookie已经存在,那么SID将为(未定义)空 */ ?> <?php // page2.php session_start(); print $_SESSION['animal']; // 打印出单个session var_dump($_SESSION); // 打印出page1.php传过来的session值 ?>
2.3 使用session函数控制页面缓存.
很多情况下,我们要确定我们的网页是否在客户端缓存,或要设置缓存的有效时间,比如我们的网页上有些敏感内容并且要登录才能查看,如果缓存到本地了,可以直接打开本地的缓存就可以不登录而浏览到网页了.
使用session_cache_limiter('private');可以控制页面客户端缓存,必须在session_start()之前调用. 更多参数见Unix.net/u/27731/showart.php?id=258087">http://blog.chinaunix.net/u/27731/showart.php?id=258087的客户端缓存控制.
控制客户端缓存时间用 session_cache_expire(int);单位(s).也要在session_start()前调用.
这只是使用session的情况下控制缓存的方法,我们还可以在header()中控制控制页面的缓存.
2.4 删除session
要三步实现.
<?php session_destroy(); // 第一步: 删除服务器端session文件,这使用 setcookie(session_name(),'',time()-3600); // 第二步: 删除实际的session: $_SESSION = array(); // 第三步: 删除$_SESSION全局变量数组
|