使用SESSION实现PHP会话的步骤

使用SESSION实现PHP会话的步骤

从事PHP开发的朋友都知道,在PHP中可以使用SESSION来实现一个会话控制,那么具体要怎样去实现?对于新手来说掌握这一方法尤其重要。一般来说,一个会话有如下几个基本的步骤:

1.开启一个会话

2.注册会话变量

3.使用会话变量

4.注销变量并销毁会话

当然,这些步骤也不一定都要发生在同一个PHP脚本中,其中的一些步骤可以在多个PHP脚本中发生。下面,就来依次具体的谈谈这些步骤。

一、开启一个会话

在使用会话功能前,必须开启一个会话。PHP提供了两种方法来开启一个会话。

第一种方法,就是调用PHP内置函数sesseion_start()来开始一段脚本,这也是最简单的一种方法。

该函数将检查是否存在一个会话ID。如果已经存在会话ID,就将这个已经注册的会话变量载入以便后面使用。如果不存在,就创建一个会话ID,并且使用其能够通过超级全局变量数组$_SESSION进行访问。在要使用到会话的脚本开始部分必须调用session_start()函数。如果没有调用,所有保存在该会话的信息都无法在当前脚本中使用。

第二种方法是将PHP设置成当有用户访问网站的时候就自动开启一个会话。在php.ini文件中的session.auto_start选项完成该设置。不过这种方法有一个很大的缺点:启用auto_start设置导致无法使用对象作为会话变量。这是因为该对象的类定义必须在创建该对象的会话开始之前载入。

二、注册一个会话变量

从PHP4.1版本之后,我们可以将会话变量保存在超级全局数组$_SESSION中。要创建一个会话变量,只需在这些数组中设置一个数组元素,如下实例:

$_SESSION['myage'] = 18;

注意,使用超级全局数组$_SESSION创建会话变量只有在会话结束或者手动重置它时才会失效。根据php.ini文件对会话gc_maxlifttime指令设置,该会话也可能会过期。该指令确定会话的持续时间(单位为秒),超过设置时间,该会话将被自动结束。

三、使用会话变量

上面步骤中有提到过,要在当前脚本中使用已保存的会话变量,必须首先使用session_start()函数启动一个会话。使用该函数之后,就可以通过超级全局数组$_SESSION访问保存的会话变量了,例如,

$_SESSION['myage']。

当使用对象作为会话变量时,在调用session_start()函数重新载入会话变量之前,必须包含该类对象的定义。这样,PHP就知道如何构建这个会话对象。

相反,在检查会话变量是否已经被设置时,必须非常小心。请注意,变量可以被用户通过GET或都POST设置。可以通过检查$_SESSION数组来确定一个变量是否是注册的会话变量。可以通过如下所示的代码来检查:

if(isset($_SESSION['myage']))...

四、注销变量与销毁会话

要结束一个会话,首先要注销会话变量,然后销毁会话。当使用完一个会话变量后,就可以将其注销。通过$_SESSION数组的适当元素,可以直接注销会话变量,实例如下:

unset($_SESSION['myage']);

我们不能直接销毁整个$_SESSION数组,因为这样将禁用会话功能。要一次销毁所有的会话变量,可以使用如下所示的语句:

$_SESSION = array();

当使用完一个会话之后,首先应用注销所有变量,然后再调用:session_destroy()来清除会话ID。

至此,使用SESSION实现简单会话的步骤已经全部结束。