Php 简明教程

PHP - Sessions

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

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

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

Starting a Session

为了启用对会话数据的访问,必须调用 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

Example

请看以下示例:

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

浏览器会将一个随机字符串显示为 output

Session Id: mi3976f8ssethe9f04vq1ag6it

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

php sessions 1

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

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

Handling Session Variables

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

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

$_SESSION[ "var"]=value;

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

echo $_SESSION[ "var"];

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

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

Example

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

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

以下 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

Destroying a PHP Session

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

以下是 unset a single variable 的示例 −

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

以下是将会 destroy all the session variables 的调用 −

<?php
   session_destroy();
?>

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

Example

以下 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

Submit 按钮。浏览器将显示已创建的会话变量 −

php sessions 3

浏览器通过遵循所示的链接导航到另一个页面。它读回会话变量。

php sessions 4