3.1.4 PHP中的session
session是Web开发中最常见的概念,也是最常用的功能之一。简单地说,session是指用户进入网站到浏览器关闭的这段时间(或过程)。
HTTP是面向无连接(或无状态)的协议。这意味着,在HTTP中,一个完整的请求/响应过程结束之后,客户端(即浏览器)和服务器端的链接就已中断。此时,如果用户再从当前页面访问其他页面,即向服务器端发出请求,服务器端并不知道此请求是哪个用户发起的,因此也就无法得知用户的浏览状态。这样就遇到一个问题:当前页面中的某个数据(或变量),无法在接下来访问的页面中使用。而在实际的Web开发中,经常要在页面之间传递数据,而且不同的访问用户传递的数据是不同的。虽然解决这个问题的办法有很多,但通过session解决这个问题,会更加方便、快速、有效。通过session记录用户的有关信息,以供用户以此身份向服务器端发起请求时,服务器端能够根据session做出正确的判断,区分不同用户的请求。
在PHP中使用session,就是通过注册一些session全局变量,在不同页面的程序中使用这些变量。这样就可以通过session完成用户身份验证、程序状态和页面之间的数据传递等功能。
一般使用类似$_SESSION['session_name']=session_value的代码注册一个session变量,其用法也和$_POST、$_GET类似。另外,在使用session的页面中,需要使用sesssion_star()函数,它表示开始或返回一个已经存在的session。这个函数要在浏览器有任何输出之前调用,也就是说,它往往是使用session的程序的第一行代码。
下面通过一个实例来理解session的使用。这个实例中有两个PHP程序,在第1个程序中,定义一些session变量,如代码3-4所示,然后通过第1个页面中的链接,请求第2个PHP程序。在第2个程序中,输出通过session前一个页面定义的session变量,如代码3-5所示。
代码3-4 在PHP程序中注册session变量3-4.php
01 <?php
02 session_start();//使用session前必须调用该函数
03
04 $_SESSION['user']='KingKong';//注册一个session变量,变量的值为“KingKong”
05 $_SESSION['explain']='这是3-4.php的session变量';
06 echo'这个页面已经通过session保存了一些变量';
07 echo'<br/><a href="3-5.php">进入3-5.php</a>查看这些变量值';
08 ?>
代码3-5 在PHP程序中取得session变量的值3-5.php
09 <?php
10 session_start();
11 echo$_SESSION['user']."<br/>";
12 echo$_SESSION['explain']."<br/>";
13 echo'<a href="3-4.php">返回3-4.php</a>';
14 ?>
【代码解析】第4~5行注册两个session变量,然后通过第11~12行进行读取和输出。
访问3-4.php,然后通过该页面的“进入3-5.php”的链接,访问3-5.php,可以看到如图3-7所示的结果。程序3-5.php通过session取得了在3-4.php中注册的session变量,实现了数据的跨页面传递。
说明 上述传递session变量功能的实现,是基于客户端浏览器支持cookie的。cookie是由服务器端产生的并且保存在客户端的一些文件,里面存放了一些用户信息和数据。有关cookie的知识会在第8章介绍。因为PHP的session机制是通过cookie实现的,所以,如果浏览器不支持cookie,那么上述的示例程序就无法看到预期的效果。
共有条评论 网友评论