實現多域名下共用一個SESSION
要實現多域名共享session,首先就得了解SESSION的運作機制。基本概念我就不說了。
session是這樣運作的:
用戶A訪問站點Y,如果站點Y執行了session_start();(以下假定session_start()總是存在)那麼會產生一個session_id,這個session id一般會以COOKIE的形式保存到使用者A(我們可以透過在php.ini裡設定session.use_only_cookies為1,強制SESSION ID必須以COOKIE傳遞。)。這時候SESSION ID表現為$_COOKIE['PHPSESSID'];(PHPSESSID可用session_name()函數來修改)
用戶A接著訪問,這個session id($_COOKIE['PHPSESSID'])就會在A每次訪問Y的時候傳送到站點Y。
在站點Y上,會有這麼一個目錄,是用來保存SESSION的實際資料的。站點Y接收到session id,然後透過session id,來獲得與SESSION資料的關聯,並傳回SESSION資料。
可能聰明的你已經想到了,既然伺服器端和客戶端之間的SESSION是透過一個SESSION ID來聯繫,並且SESSION資料是以普通檔案的形式保存在一個特定的資料夾裡。
那麼我們要實現不同域名,只需要滿足以下兩個條件:
1)不同域名的SESSION資料目錄統一到一起,或是同步更新。
2)對同一個客戶,使用統一的一個SESSION ID
第一個條件的實作。
如果是同一台伺服器,就不需要進行任何設定了。
如果是群集/分散式的,那我想也不需要我來說了。 。能做分散式應用的,在目錄分享的經驗應該比我豐富。我也沒有進行過多伺服器的測試,主客觀條件的原因都有。
我在這裡主要是想說第二個條件——使不同的域名,擁有統一的SESSION ID。
那我們該怎麼統一呢?
首先必須在不同網域之間傳遞這個SESSION ID,且由於 cookie必須是針對網域的,所以傳遞動作是由客戶端來完成。如果傳遞過程不是由客戶端來完成,那麼接受傳遞的網域就不知道針對的是哪個客戶。
其次就是修改接受傳遞的網域下的SESSION ID。
如何傳遞:
HTML裡,我們可以使用很多種方法。例如
iframe
或.js
或是一個img html元素
只要能呼叫某個地址,就行。
在wml裡,由於wml script的特點,我們無法使用script這樣的形式來調用,而wml裡也沒iframe..但是我們還是可以通過img來實現傳遞的。
如何修改:
既然SESSION ID一般情況下是透過COOKIE來傳遞,那麼我們只需要透過傳遞$_COOKIE['PHPSESSID'];即可。但如果PHPSESSID被session_name改變了,我們又得修改setcookie中的PHPSESSID..這樣就會變得很麻煩。 。所以我們可以選擇一個session特有的函數session_id來修改$_COOKIE['PHPSESSID'];
需要注意的幾點:
如果session.use_only_cookies為0(PHP預設),那麼session id有可能會以url或url其他形式傳遞
session_id()和session_name必須在session_start()前使用
以下是我寫的一個簡單的實現多域名的類別。如果上面的看不太明白,可以看看我的這個多網域類別。這個類別是在HTML下以iframe形式實作的。
/*
使用:
伺服器A,伺服器B,在A的index.php登陸,在B裡建立一個接收SESSION的文件,例如ses_get.php
A的index.php做如下修改
最修改
開始加上session_start();
而ses_get.php則在開頭寫mdSession::_get ();
@作者:surfchen@gmail.com http://www.surfchen.org/ */
function mdSession()
{
} 函數!is_array($urls))
{ $urls=array($urls); } foreach ($urls as $value)
{ echo ''; } return true; } function get()
{ session_id($_SERVER['QUERY_STRING']); session_start( ); return true; } function _set($urls)
{ $obj=new mdSession(); return $obj->set($urls); } function _get()
{ $obj=new mdSession(); return $ obj->get(); }
}?>
index.php :
include "mdSession.php";
include "mdSession.php";include "mdSession。 ']="yogurt8";
mdSession::_set('http://www.b.com/ses_get.php');
var_dump($_SESSION);
?>
.
include "mdSession.php";
mdSession::_get();
?>
b.php 或ION);
先訪問http://www.a.com/a.php 然後在http://www.b.com/b.php 看效果
在firefox 與Google瀏覽器是沒問題,Google瀏覽器是沒問題,但在Ie 下還是不行

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

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

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

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

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

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

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

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