国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

Asp中如何設計跨越域的Cookie

2024-05-04 11:07:05
字體:
來源:轉載
供稿:網友

 Cookie簡介

  首先,我們對Cookie做一個簡單的介紹,說明如何利用ASP來維護cookie。

  Cookie是存儲在客戶端計算機中的一個小文件,這就意味著每當一個用戶訪問你的站點,你就可以秘密地在它的硬盤上放置一個包含有關信息的文件。這個文件幾乎可以包含任何你打算設置的信息,包括用戶信息、站點狀態等等。這樣的話,就有一個潛在的危險:這些信息有可能被黑客讀取。為了防止這個問題的發生,一個有效的辦法就是cookie只能被創建它的域所存取。這就是說:比如ytu.edu.cn只能訪問ytu.edu.cn創建的cookie。通常來講,這沒有什么問題;但是,如果需要兩個不同域上的兩個不同站點共享保存在cookie中的用戶信息,該如何處理呢?當然可以選擇復制用戶信,但是,如果你需要用戶只能在一個站點上注冊,并且自東成為另外一個站點的注冊用戶呢?或者,兩個站點共享一個用戶數據庫,而又需要用戶自動登錄呢?這時候,跨越域共享cookie是最好的解決方案。  

  這里,先看一些ASP處理cookie的代碼,以便以后便于引用參考。

  '創建Cookie

  Response.Cookies("MyCookie").Expires=Date+365

  Response.Cookies("MyCookle").Domain="mydomaln.com"

  Response.Cookies("MyCookle")("Username")=strUsername

  Response.Cookies("MyCookle")("Password")=strPassword

  讀寫cookie非常簡單,上面的代碼創建一個cookie并給cookie設置屬性:域、過期時間,以及其他一些保存在cookie中的值。這里,strUsename,strPassword是在前面某個地方設置的變量。然后,通過下面的語句在cookie中讀取。

  '讀取Cookie

  datExpDate=Request.Cookies("MyCookie")

  strDomaln=Request.Cookies("MyCookle").Domain

  strUsername=Request.Cookies("MyCookle")("Username")

  strPassword=Request.Cookies("MyCookie")("Password")

  更詳細的信息,可以參考ASP的資料。

  實現

  簡單地共享cookie的訣竅是重定向,一般過程為:

  1.一個用戶點擊siteA.com。

  2.如果用戶沒有siteA.com的cookie,就把用戶重定向到siteB.com。

  3.如果用戶有siteB.com的cookie,把用戶連同一個特殊的標志(將在下面解釋)重定向回siteA.com,否則,只把用戶重定向到siteA.com。

  4.在siteA.com創建cookie。

  看起來很簡單,仔細分析一下:siteA.com和siteB.com共享相同的用戶設置,所以,如果用戶有siteB.com的cookie(已經注冊),siteA.com能夠同樣讀取cookie、提供cookie所允許的特性。這樣,訪問siteA.com的用戶就如同訪問了siteB.com。

  這個檢查的環節應該在siteA.com中的文件所包含一個cookies.inc中實現。讓我們看一下這段代碼:

  l—1

  'SiteA.com"檢查cookie

  If Request.Querystring("Checked")<>"True" then

  If not Request.Cookies("SiteA_Cookie").Haskeys then

  '重走向到siteB.com

  Response.Redlrect("http://www.siteB.com/cookie.asp")

  End if

  End if

  如果用戶有一個siteA.com的cookie,則不需要做任何事情了;第一個if語句用來消除無限的循環。讓我們看一下siteB.com上的cookie.asp文件來獲得進一步的理解。

  1—2

  'SiteB.com

  '檢查cookie

  If not Request.Cookies("SlteB_Cookle").Haskeys then

  '重定向到 siteA.com

  Response.Redirect("http://www.siteA.com/index.asp"&"?checked=True")

  Else

  '獲取username

  strUsername=Request.Cookies("SiteB_Cookie")("Username")

  '將用戶連同一個特殊的標志返回到siteA.com

  Response.Redlrect("http://www.siteA.com/index.asp"&"?checked=True"&"identrfer="&strUsername)

  End if

  如果用戶在siteB.com上仍沒有cookie,于是,將他送回到siteA.com,并且通過在查詢語句中提供一個叫做"checkd"的參數讓應用程序知道你已經檢查過cookie了。否則,將用戶送回到siteB.com,并退出循環。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 高尔夫| 浦北县| 佛教| 南平市| 呼伦贝尔市| 建瓯市| 肇东市| 当阳市| 丰城市| 东兴市| 蛟河市| 闽侯县| 通山县| 霍林郭勒市| 新绛县| 农安县| 凤山市| 浦北县| 远安县| 宝坻区| 凯里市| 鹤壁市| 宁津县| 斗六市| 高州市| 安徽省| 元阳县| 哈巴河县| 班玛县| 东源县| 龙胜| 敦化市| 古蔺县| 个旧市| 文山县| 建湖县| 大连市| 凯里市| 横山县| 郎溪县| 大新县|