首頁  >  文章  >  後端開發  >  如何解決php session跨頁遺失問題

如何解決php session跨頁遺失問題

PHPz
PHPz原創
2020-09-25 15:43:442723瀏覽

php session跨頁遺失的解決方法:1、設定「php.ini」中的「session.use_trans_sid=1」;2、手動透過URL傳值或隱藏表單傳遞session id;3、用文件或資料庫等形式保存“session_i”。

如何解決php session跨頁遺失問題

推薦:《PHP影片教學

簡介:

PHP中SESSION遺失(不能跨頁面傳遞)解決辦法

一般來說,讓SESSION遺失有以下幾點:

1、客戶端停用了cookie

2、瀏覽器無法儲存取cookie

3、php.ini中的session.use_trans_sid=0或編譯時沒有開啟–enable-trans-sid選項

Session儲存於伺服器端(預設以檔案方式儲存) ,根據客戶端提供的session id來得到使用者的文件,

取得變數的值,session id可以使用客戶端的Cookie或Http1.1協定的Query_String

#(就是存取的URL的「?」後面的部分)來傳送給伺服器,然後伺服器讀取Session的目錄…。也就是說,

session id是取得儲存在服務上的session變數的身分證。當程式碼session_start();運行的時候,

就在伺服器上產生了一個session文件,隨之也產生了與之唯一對應的一個session id,

定義session變數以一定形式儲存在剛才產生的session檔案中。透過session id,

可以取出定義的變數。跨頁後,為了使用session,你必須又執行session_start();

將會又會產生一個session文件,與之對應產生對應的session id,

用這個session id是取不出前面提到的第一個session檔案中的變數的,

因為這個session id不是打開它的「鑰匙」。如果在session_start();

之前加程式碼session_id($session id);將不產生新的session文件,

直接讀取與這個id對應的session文件。

PHP中的session在預設情況下是使用客戶端的Cookie來保存session id的,

所以當客戶端的cookie出現問題的時候就會影響session了。必須注意的是:

session不一定必須依賴cookie,這也是session相比cookie的高明之處。

當客戶端的Cookie被停用或出現問題時,PHP會自動把session id附著在URL中,

這樣再透過session id就能跨頁使用session變數了。但這種附著也是有一定條件的,

即「php.ini中的session.use_trans_sid = 1或編譯時開啟開啟了–enable-trans-sid選項」。

明白了以上的道理,現在我們來拋開cookie使用session,主要途徑有三條:

1、設定php.ini中的session.use_trans_sid = 1或編譯時打開了–enable-trans-sid選項,

讓PHP自動跨頁傳遞session id。

2、手動透過URL傳值、隱藏表單傳遞session id。

3、用檔案、資料庫等形式儲存session_id,在跨頁過程中手動呼叫。

以上是如何解決php session跨頁遺失問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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