您好,登錄后才能下訂單哦!
php中session的原理是什么?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
Session的簡介
在計算機中,尤其是在網絡應用中,稱為“會話控制”。Session 對象存儲特定用戶會話所需的屬性及配置信息。這樣,當用戶在應用程序的 Web 頁之間跳轉時,存儲在 Session 對象中的變量將不會丟失,而是在整個用戶會話中一直存在下去。當用戶請求來自應用程序的 Web 頁時,如果該用戶還沒有會話,則 Web 服務器將自動創建一個 Session 對象。當會話過期或被放棄后,服務器將終止該會話。Session 對象最常見的一個用法就是存儲用戶的首選項。
Session的機制
session機制采用的是在服務器端保持狀態的方案,并且有自己對應的唯一標識session_id,區分不同用戶之前的信息。
Session的工作原理
當一個session第一次被啟用時,一個唯一的標識被存儲于本地的cookie中;
首先使用session_start()函數,PHP從session倉庫中加載已經存儲的session變量;
當執行PHP腳本時,通過使用session_register()函數注冊session變量。
當PHP腳本執行結束時,未被銷毀的session變量會被自動保存在本地一定路徑下的session庫中,這個路徑可以通過php.ini文件中的session.save_path指定,下次瀏覽網頁時可以加載使用。
Session的優缺點
優點
唯一性、方便調用、不會過多占用資源,是存儲在服務器的一組臨時數據。一般情況下,我們在做用戶登錄時,會將用戶數據存入session。這樣,在任何頁面都可以方便調用,而且每個客戶端會產生唯一的session_id,不會混淆。并且在關閉瀏覽器后,服務器會有session回收機制,自動刪除過期session。
缺點
在客戶端是以cookie方式保存的,禁用cookie,session就失效了。
關于php中session的原理是什么問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。