我們擁有客製化服務,遮陽隔音防熱多功能,天熱不心煩節能新選擇 免費到府估價,價格公道 | 多年油漆相關服務經驗,專業的油漆工程 裝潢設計之首選,免費估價。 |
cookie 跨域名的寫法 |
房東:高手 發表時間:2007-01-18 | [檢舉] |
Cookie真是一個偉大的發明,它允逕eb開發者保留他們的用戶的登錄狀態。然而,當你的站點或網絡 有一個以上的域名時就會出現問題了。 在Cookie規範上說,一個cookie只能用於一個域名,不能夠發給其它的域名。因此,如果在瀏覽器中對一個域名設置了一個cookie,這個cookie對於其它的域名將無效。如果你想讓你的用戶從你的站點中的其中一個進行登錄,同時也可以在其它域名上進行登錄,這可真是一個大難題。 我的解決方案將使用下面的一般框架: 一個預置的腳本將用來接受通過GET或COOKIE方式傳遞過來的sessionid號。它將比COOKIE優先選擇GET 變量。所以,無論何時需要引用交叉的域名時,我們把sessionid做為一個URL參數進行發送。修改Apache配置,用來實現重寫所有的交叉域名的cookie。這樣做的原因一會兒就會清楚了。在任何時候出現一個交叉域名引用時使用變量。 第一步:創建預置腳本 將下面的代碼加到預置腳本中(或出現在所有腳本之前的函數中)。 /* 支持交叉域名cookie... */ // 如果GET變量已經設置了,並且它與cookie變量不同 //則使用get變量(更新cookie) global $HTTP_COOKIE_VARS, $HTTP_GET_VARS; if (isset($sessionid) && isset($HTTP_GET_VARS[\'sessionid\']) && ($HTTP_COOKIE_VARS[\'sessionid\'] != $HTTP_GET_VARS[\'sessionid\'])) { SetCookie(\'sessionid\', $HTTP_GET_VARS[\'sessionid\'], 0, \'/\', \'\'); $HTTP_COOKIE_VARS[\'sessionid\'] = $HTTP_GET_VARS[\'sessionid\']; $sessionid = $HTTP_GET_VARS[\'sessionid\']; } ?> 一旦這個代碼運行之後,一個全局的\'sessionid\'變量將可以用於腳本。它將保存著用戶的cookie中的 sessionid值,或者是通過GET請求發來的sessionid值。 第二步:為所有的交叉域名引用使用變量 創建一個全局的配置文件,用於存放可以進行切換的域名的基本引用形式。例如,如果我們擁有 domain1.com和domain2.com,則如下設置: $domains[\'domain1\'] = \"http://www.domain1.com/-$sessionid-\"; $domains[\'domain2\'] = \"http://www.domain2.com/-$sessionid-\"; ?> 現在,如果在代碼中如下做: echo \"Click here to contact us.\"; ?> 你將產生如下的輸出: Click here to contact us. 在這裡sessionid已經被插入到URL中去了。 在這個地方,你可能會想\"這樣可能會在web服務器上打開名為橫線,sessionid,橫線的子目錄?!?!?\"。 然而,下面的步驟將提供一個必需的戲法,以便讓它能夠使用! 第三步:配置Apache 現在,剩下的步驟就是配置apache來重寫這個URL: http://www.domain2.com/-66543afe6543asdf6asd-/contact/ 變成這樣: http://www.domain2.com/contact/?sessionid=66543afe6543asdf6asd 並且這種url: http://www.domain2.com/-66543afe6543asdf6asd-/contact/?email=yes 變成這樣: http://www.domain2.com/contact/?email=yes&sessionid=66543afe6543asdf6asd 為了實現它,簡單地配置兩個虛擬服務器,作為domain1和domain2,如下操作: DocumentRoot /usr/local/www/domain1 ServerName www.domain1.com RewriteEngine on RewriteRule ^/-(.*)-(.*?.*)$ &sessionid= [L,R,QSA] RewriteRule ^/-(.*)-(.*)$ ?sessionid= [L,R,QSA] DocumentRoot /usr/local/www/domain2 ServerName www.domain2.com RewriteEngine on RewriteRule ^/-(.*)-(.*?.*)$ &sessionid= [L,R,QSA] RewriteRule ^/-(.*)-(.*)$ ?sessionid= [L,R,QSA] 這些重寫的規則實現了上面兩個URL重寫的要求。 結論 通過使用變量結合與apache的重寫弁遄A交叉域名cookie可以以一種簡單的方式實現。想要維護這樣的 系統,無論什麼時候鏈接交叉域名,在使用域名變量之外,什麼也不用作了!在域名內部的鏈接不需要進行 修改,因為cookie會工作正常。 如果你有興趣看一下在生產網絡中實際運作中的系統,請參觀http://www.familyhealth.com.au/。在 一些交叉域名鏈接上移動你的鼠標,並且看一下當你點擊後它們是如何被重寫的。 也部A使用這個技術唯一的問題就是無法刪除在用戶瀏覽器中的全部域名下的cookie。 |
廣利不動產-新板特區指名度最高、值得您信賴的好房仲 您的托付,廣利用心為您服務 廣利不動產-板橋在地生根最實在--新板特區指名度最高、值得您信賴的好房仲 完整房訊,房屋、店面熱門精選物件,廣利不動產 優質仲介,房屋租賃、買賣資訊透明,交易真安心! |