首頁 後端開發 php教程 深入理解PHP的Session機制

深入理解PHP的Session機制

Aug 08, 2016 am 09:28 AM
cookie id php save session

今天在看鳥哥的 如何設定一個嚴格30分鐘過期的Session 這篇文章的時候
對php的session機制產生了興趣,在網路上找了點資料來研究了下

php會話管理系統支援許多設定選項,可以在自己的 php.ini 檔案中設定
在php.ini對於session的配置中,session.save_handler 定義了來儲存和取得與會話關聯的資料的處理器的名字,預設為files,需要注意的是個別的擴充可以註冊自己的save_handlers;註冊的處理程式可在每個安裝基礎透過參考的phpinfo()取得。參見一下session_set_save_handler()。
PHP配置中對於會話的處理有2種方式,一種是預設的files,一種是user使用者自訂的。
一、session.save_handler=files
1. session_start()
1.1 session_start()是session機制的開始,它有一定機率開啟垃圾回收,因為session是存放在檔案中,PHP本身的垃圾回收是對SESSION會話無效的,SESSION的回收是要刪檔案的,這個機率是根據php.ini的配置(session.save_path)決定的。
有的系統是 session.gc_probability = 0,這也就是說機率是0,而是透過cron腳本來實現垃圾回收。

<code>            session<span>.gc</span>_probability = <span>1</span>
            session<span>.gc</span>_divisor = <span>100</span>
            session<span>.gc</span>_maxlifetime = <span>1440</span>//过期时间 默认<span>24</span>分钟
            //概率是 session<span>.gc</span>_probability/session<span>.gc</span>_divisor 结果 <span>1</span>/<span>100</span>, 
            //不建议设置过小,因为session的垃圾回收,是需要检查每个文件是否过期的。
            session<span>.save</span>_path = //好像不同的系统默认不一样,有一种设置是 <span>"N;/path"</span>
            //这是随机分级存储,这个样的话,垃圾回收将不起作用,需要自己写脚本</code>
登入後複製

1.2 session會判斷當前是否有$_COOKIE[session_name()];session_name()返回保存session_id的COOKIE鍵值,這個值可以從php.ini找到

<code><span>session.name </span>=<span> PHPSESSID //默认值PHPSESSID</span></code>
登入後複製

1.3 如果不存在會生成一個session_id,然後把產生的session_id當作COOKIE的值傳遞到客戶端。相當於執行了下面COOKIE 操作,注意的是,這一步驟執行了setcookie()操作,COOKIE是在header頭中發送的,這之前是不能有輸出的,PHP有另外一個函數session_regenerate_id() 如果使用這個函數,這之前也是不能有輸出的。

<code>    setcookie(session_name(),
              session_id(),
              session.cookie_lifetime,<span>//</span>默认<span>0</span>
              session.cookie_path,<span>//</span>默认<span>'/'</span>当前程序跟目录下都有效
              session.cookie_domain,<span>//</span>默认为空
              )</code>
登入後複製

1.4 如果存在那麼session_id = $_COOKIE[session_name] ;
然後去session.save_path指定的資料夾裡面取找名字為’SESS_’ . session_id()的檔案。
讀取檔案的內容反序列化,然後放到$_SESSION 全域變數中
2. 為 $_SESSION 賦值
例如新加入一個值$_SESSION['test']= 'test'; 那麼這個$_SESSION只會維護在內容中,當腳本執行結束的時候,把$_SESSION的值寫入到session_id指定的資料夾中,然後關閉相關資源. 這個階段有可能執行更改session_id的操作。
例如銷毀一個舊的session_id,產生一個全新的session_id.一半用在自訂 session操作,角色的轉換上,例如Drupal.Drupal的匿名使用者有一個SESSION的,當它登入後需要換用新的session_id。

<code>if (<span>isset($_COOKIE[<span>session_name()</span>])</span>) {
          <span>setcookie(<span>session_name()</span>, <span>''</span>, <span>time()</span> - <span>42000</span>, <span>'/'</span>)</span>;<span>//旧session cookie过期</span>
        }
        <span>session_regenerate_id()</span>;<span>//这一步会生成新的session_id</span><span>//session_id()返回的是新的值</span></code>
登入後複製

3.寫入SESSION操作
在腳本結束的時候會執行SESSION寫入操作,把$_SESSION中值寫入到session_id命名的檔案中,可能已經存在,可能需要建立新的檔案。
4. 銷毀SESSION
SESSION發出去的COOKIE一般屬於即時COOKIE,保存在內存中,當瀏覽器關閉後,才會過期,假如需要人為強制過期,比如退出登錄,而不是關閉瀏覽器,那麼就需要在代碼裡銷毀SESSION,方法有很多.
4.1 setcookie(session_name(), session_id(), time() - 8000000, ..);//登出登入前執行
4.2 usset($_SESSION);//這會刪除所有的$_SESSION數據,刷新後,有COOKIE傳過來,但是沒有數據。
4.3 session_destroy();//這個作用更徹底,刪除$_SESSION 刪除session文件,和session_id
當不關閉瀏覽器的情況下,再刷新,2和3都會有COOKIE傳過來,但找不到資料

二、session.save_handler=user
在php手冊中有session_set_save_handler 來 設定使用者自訂會話儲存函數, 如果想使用 PHP 內建的會話儲存機制以外的方式, 可以使用本函數。 例如,可以自訂會話儲存函數來將會話資料儲存到資料庫。
具體可以查看PHP手冊 http://php.net/manual/zh/function.session-set-save-handler.php

以上就介紹了深入理解PHP的Session機制,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

php程序在字符串中計數元音 php程序在字符串中計數元音 Feb 07, 2025 pm 12:12 PM

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? 什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? Apr 03, 2025 am 12:03 AM

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP和Python:比較兩種流行的編程語言 PHP和Python:比較兩種流行的編程語言 Apr 14, 2025 am 12:13 AM

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

See all articles