PHP - Session


Web 会话( session )是用户与服务器建立连接与连接终止之间的持续时间。除了 cookie 之外,session 变量还可以在整个网站的各个页面访问数据。

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

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

启动 session

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


 session_start(array $options = []): bool

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

PHP 首先为该特定 session ​​​​​​​创建一个唯一标识符,它是一个由 32 个十六进制数字组成的随机字符串。

session_id() 函数设置或检索唯一的 session ​​​​​​​ ID。


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

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

例子

请看下面的例子 -


<?php  
   // 开始会话session
   session_start();
   $id = session_id();
   echo "Session Id: ".$id ;
?>

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

Session Id: mi3976f8ssethe9f04vq1ag6it

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

PHP 会话 1

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

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

处理 session ​​​​​​​变量

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

要创建新的 session ​​​​​​​变量,请在 $_SESSION 数组中添加键值对 −


 $_SESSION[ "var"]=value;

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


 echo $_SESSION[ "var"];

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


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

例子

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

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

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


<?php
   session_start();
   if( isset( $_SESSION['counter'] ) ) {
      $_SESSION['counter'] += 1;
   } else {
      $_SESSION['counter'] = 1;
   }
   $msg = "本次session的访问次数: ".  $_SESSION['counter'];
?>
<?php  
   echo "$msg"; 
?>

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

本次session的访问次数: 5

销毁 session ​​​​​​​

PHP  session ​​​​​​​可以通过 session_destroy() 函数销毁。此函数不需要任何参数,并且单个调用可以销毁所有 session ​​​​​​​变量。如果你想销毁单个 session ​​​​​​​变量,那么你可以使用 unset() 函数来取消设置 session ​​​​​​​变量。

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


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

这是将销毁所有 session ​​​​​​​变量的调用——


<?php
   session_destroy();
?>

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

例子

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


<html>
<body>
   <form action="<?php echo $_SERVER['PHP_SELF'];?>" method="post">
      <h3>用户 ID: <input type="text" name="ID"/></h3>
      <h3>用户 Name: <input type="text" name="name"/></h3>
      <h3>用户 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>已创建以下 session 变量</h2>";
         foreach ($_SESSION as $key=>$val) {
            echo "<h3>" . $key . "=>" . $val . "</h3>";
         }
         echo "<a href='test.php'><b>点击这里</b></a>";
      }
   ?>
</body>
</html>

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

PHP 会话 2

按 Submit 按钮。浏览器将显示创建的 session ​​​​​​​变量 -

PHP 会话 3

浏览器将按照显示的链接导航到另一个页面,它会读回 session ​​​​​​​变量。