PHP中Session和Cookie是如何操作的_php技巧
Session PHP的$_SESSION可以存储当前用户数据信息,用户访问WEB网站的时候,PHP会给每个访问的用户创建一个session ID,该ID是唯一ID,保存在客户机上,而用户的会话数据是保存到服务端的,PHP可以对每个不同的用户信息进行存储,当会话过期后,用户session信息也会失效。 使用Session,在使用PHP session时,一定要在页头加上session_start(),告诉服务器开始使用session了,而且在它之前应该没有任何输出,否则会报错。 <?php session_start(); //PHP 代码... ?> PHP设置与获取Session <?php session_start(); //设置一个session值 $_SESSION["name"] = "Hello"; //将session以数组形式保存 $_SESSION["arr"] = array('name' => 'Hello', 'url' => 'http://www.helloweba.com', 'type'=> 'website'); ?> 一旦储存了Session数据,我们就可以在网站上使用Session,比如我们在另一个页面就可以获取Session数据: <?php session_start(); //获取保存的Session name echo $_SESSION["name"]; //打印数组session print_r($_SESSION["arr"]); ?> PHP删除Session <?php unset($_SESSION["name"]); ?> 如果要清空当前用户所有的Session信息可以使用以下代码: <?php session_destroy(); ?> Cookie <?php $cookie_val = 'Chrome'; setcookie("browser", $cookie_val, time()+3600); ?> 运行以上代码,将会创建一个名称为Chrome的Cookie,并且在客户端保存1个小时,1小时后该cookie信息失效。 <?php if(isset($_COOKIE['browser'])) { echo '您的浏览器是:' . $_COOKIE['browser']; } ?> PHP删除Cookie <?php setcookie("browser", "", time()-3600); ?> 以上代码将名称为browser的cookie清空,并将有效期设置到1小时前,完全清空了cookie信息。 |