本文主要和大家分享php之session和cookie總結,希望能幫助大家。
1.cookie與session的關係
cookie和session的方案雖然分別屬於客戶端和服務端,但是服務端的session的實現對客戶端的cookie有依賴關係的;步驟大概如下:
1.服務端執行Session機制
2.產生對應而唯一的session_id(透過對這個session_id的解析和處理,服務端可以找到,該session保存的檔案;再從檔案中提取出session的信息) 076402276aae5dbec7f672f8f4e5cc81
3.服務端會將這個session_id發送給客戶端
客戶端接受到session_id,以cookie作為保存的容器保存起來
4.客戶端在每次請求的時候都會帶這個session_id給服務端
服務端自行解析session
注意:session保存資訊的手段是多種的:緩存,資料庫,檔案等;但是預設是檔案形式保存。 。 。
2.創建 session和銷毀session的時機
創建session的時候會附帶創建一個cookie,它的MaxAge為-1,也就是說只能存在於內存中。當瀏覽器端停用cookie時,這個cookie依然會被創建。
當瀏覽器提交的請求中有jsessionid參數或cookie標頭時,容器不再新建session,而只是找到先前的session進行關聯。這裡又分為兩種情況:
1)使用jsessionid。該值若能與現有的session對應,就不會建立新的session,否則,仍會建立新的session。
2)使用cookie。該值若能與現有的session對應,也不創建新的session;但若沒有session與之對應(就如上面的重啟伺服器之後)容器會根據cookie資訊恢復這個與之對應的session,就好像是以前有過一樣。
3.session何時被銷毀?
當我們關閉瀏覽器,再開啟它,連接伺服器時,伺服器端會分配一個新的session,也就是說會啟動一個新的會話。那麼原來的session是不是被銷毀了呢?我做了個小實驗:
建立一個session:
session_start();//註冊session變量,並且賦值$_SESSION["username"] = "hello"//輸出生成的session_idecho session_id();
訪問頁面建立session,取得session_id,關閉瀏覽器;
根據session_id建立session物件
$session_id = "qpk6onnn3husvotnke030ftcm4"; session_id($session_id); session_start(); echo $_SESSION["username"]; //结果取出session
所以
rrreee
所以當瀏覽器關閉時,原session並沒有被銷毀(destory方法沒有執行),而是等到timeout到期,才銷毀這個session。關閉瀏覽器只是在客戶端的記憶體中清除了與原始會話相關的cookie,再次開啟瀏覽器進行連線時,瀏覽器無法傳送cookie訊息,所以伺服器會視為一個新的會話。因此,如果有某些與session關聯的資源想在關閉瀏覽器時就進行清理(如臨時檔案等),那麼應該發送特定的請求到伺服器端,而不是等到session的自動清理。 相關推薦:
php實現會員登陸註冊頁有html加Session和Cookie
######php學習之session和cookie的區別#######以上是php之session和cookie總結分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!