PHP - 会话



Web 会话是指用户与服务器建立连接到连接终止之间的时间段。与 Cookie 一样,会话变量使数据可在整个网站的各个页面之间访问。

在会话期间,网站会维护有关用户操作和偏好的信息。会话数据填充到超全局关联数组$_SESSION中。

要在 PHP 中启动新会话,您需要调用session_start()函数。

启动会话

为了启用对会话数据的访问,必须调用session_start()函数。session_start()根据通过GET或POST请求传递的会话标识符,或通过Cookie传递的会话标识符来创建会话或恢复当前会话。

session_start(array $options = []): bool

如果会话成功启动,此函数返回true,否则返回false

PHP首先为该特定会话创建一个唯一的标识符,这是一个32个十六进制数字的随机字符串。

session_id()函数设置或检索唯一的会话ID。

session_id(?string $id = null): string|false

如果没有给出$id参数,PHP将生成一个随机会话ID。您可以改用自己的ID。该函数返回当前会话的会话ID,如果当前没有会话,则返回空字符串。失败时,它返回false

示例

看看下面的例子:

<?php  
   // Starting the session
   session_start();
   $id = session_id();
   echo "Session Id: ".$id ;
?>

浏览器将显示一个随机字符串作为输出

Session Id: mi3976f8ssethe9f04vq1ag6it

名为PHPSESSID的Cookie会自动发送到用户的计算机,以存储唯一的会话标识字符串。

PHP Sessions 1

会话在服务器上的临时目录中创建一个文件,其中存储已注册的会话变量及其值。在访问期间,网站上的所有页面都可以使用此数据。

临时文件的位置由"php.ini"文件中名为"session.save_path"的设置确定。

处理会话变量

会话变量存储在名为$_SESSION[]的关联数组中。这些变量可以在会话的生命周期内访问。

要创建一个新的会话变量,请在$_SESSION数组中添加一个键值对:

$_SESSION[ "var"]=value;

要读取会话变量的值,可以使用echo/print语句,或var_dump()或print_r()函数。

echo $_SESSION[ "var"];

要获取当前会话中所有会话变量的列表,可以使用foreach循环遍历$_SESSION:

foreach ($_SESSION as $key=>$val)
echo $key . "=>" . $val;

示例

以下示例启动一个会话,然后注册一个名为counter的变量,每次在会话期间访问页面时都会递增该变量。

使用isset()函数检查会话变量是否已设置。

以下PHP脚本在第一次运行时启动一个会话,并设置一个名为counter的会话变量。当客户端再次访问相同的URL时,由于会话变量已设置,因此计数器会递增。

<?php
   session_start();
   if( isset( $_SESSION['counter'] ) ) {
      $_SESSION['counter'] += 1;
   } else {
      $_SESSION['counter'] = 1;
   }
   $msg = "Number of visits in this session: ".  $_SESSION['counter'];
?>
<?php  
   echo "$msg"; 
?>

多次刷新浏览器以模拟重复访问。浏览器显示计数器:

Number of visits in this session: 5

销毁PHP会话

可以使用session_destroy()函数销毁PHP会话。此函数不需要任何参数,只需一次调用即可销毁所有会话变量。如果要销毁单个会话变量,则可以使用unset()函数来取消设置会话变量。

这是一个取消设置单个变量的示例:

<?php
   unset($_SESSION['counter']);
?>

这是将销毁所有会话变量的调用:

<?php
   session_destroy();
?>

如果您可以将php.ini文件中的session.auto_start变量设置为1,则当用户访问您的站点时,您无需调用start_session()函数来启动会话。

示例

以下PHP脚本呈现一个HTML表单。表单数据用于创建三个会话变量。超链接将浏览器带到另一个页面,该页面读取会话变量。

<html>
<body>
   <form action="<?php echo $_SERVER['PHP_SELF'];?>" method="post">
      <h3>User's ID: <input type="text" name="ID"/></h3>
      <h3>User's Name: <input type="text" name="name"/></h3>
      <h3>User Type: <input type="text" name="type"/></h3>
      <input type="submit" value="Submit" />
   </form>

   <?php
      session_start();
      if ($_SERVER["REQUEST_METHOD"] == "POST") {
         $_SESSION['ID'] = $_POST['ID'];
         $_SESSION['Name'] = $_POST['name'];
         $_SESSION['type'] = $_POST['type'];

         echo "<h2>Following Session variables Created</h2>";
         foreach ($_SESSION as $key=>$val) {
            echo "<h3>" . $key . "=>" . $val . "</h3>";
         }
         echo "<a href='test.php'><b>Click Here</b></a>";
      }
   ?>
</body>
</html>

将此代码另存为文档根目录中的"hello.php",然后在客户端浏览器中打开它。

PHP Sessions 2

按下提交按钮。浏览器将显示创建的会话变量:

PHP Sessions 3

浏览器通过点击显示的链接导航到另一个页面。它读取会话变量。

PHP Sessions 3
广告