1. 程式人生 > >php實現多個網站session共享

php實現多個網站session共享

    做專案經常會用到,多個專案公用一個session的情況,由於涉及到session跨域,多個專案之間公用同一個session就會存在問題,解決這種問題的方法有很多,比如session存入資料庫,Session寫入快取等等

    Session主要分兩部分:

      一個是Session資料,該資料預設情況下是存放在伺服器的tmp檔案下的,是以檔案形式存在。

     另一個是標誌著Session資料的Session Id,Session ID

,就是那個 Session 檔案的檔名,Session ID 是隨機生成的,因此能保證唯一性和隨機性,確保 Session 的安全。一般如果沒有設定 Session 的生存週期,則 Session ID 儲存在記憶體中,關閉瀏覽器後該 ID 自動登出,重新請求該頁面後,重新註冊一個 session ID。如果客戶端沒有禁用 Cookie,則 Cookie 在啟動 Session 會話的時候扮演的是儲存 Session ID Session 生存期的角色。

兩個不同的域名網站,想用同一個Session,就是牽扯到Session跨域問題;同一個域名下面部署的兩套程式碼,想用一個session也會遇到這個問題。

    預設情況下,各個伺服器會各自分別對同一個客戶端產生 SESSIONID,如對於同一個使用者瀏覽器,A 伺服器產生的 SESSION ID 是 11111111111,而B 伺服器生成的則是222222。另外,PHP 的 SESSION資料都是分別儲存在本伺服器的檔案系統中。想要共享 SESSION 資料,那就必須實現兩個目標:

    一個是各個伺服器對同一個客戶端產生的SESSION ID 必須相同,並且可通過同一個 COOKIE 進行傳遞,也就是說各個伺服器必須可以讀取同一個名為 PHPSESSID

的COOKIE;

    另一個是 SESSION 資料的儲存方式/位置必須保證各個伺服器都能夠訪問到。這兩個目標簡單地說就是多伺服器(A、B伺服器)共享客戶端的 SESSION ID,同時還必須共享伺服器端的 SESSION 資料。

   由於使用Phalcon框架作為公司專案開發框架,只需要如下簡單的入口處做如下設定就能就解決這個問題,就能輕鬆解決同一個域名下面的兩個系統,之間session共享問題:

圖片.png