程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> ASP.NET中Cookie編程簡明參考(非永久性 Cookie和永久性 Cookie)

ASP.NET中Cookie編程簡明參考(非永久性 Cookie和永久性 Cookie)

編輯:.NET實例教程

寫入CookIE

  1. Name 和 Value 屬性由程序設定,默認值都是空引用。

  2. Domain屬性的默認值為當前URL的域名部分,不管發出這個cookIE的頁面在哪個目錄下的。

  例如,http://www.kent.com/application1/login.ASPx 頁面中發出一個cookIE,Domain屬性缺省就是www.kent.com ,可以由程序設置此屬性為需要的值。

  3. Path屬性的默認值是根目錄,即 ”/” ,不管發出這個cookie的頁面在哪個目錄下的。可以由程序設置為一定的路徑來進一步限制此cookIE的作用范圍。

  4. Expires 屬性,這個屬性設置此Cookie 的過期日期和時間。如果沒有設置 Cookie 的有效期(默認設置),也可以創建 CookIE,但它不會保存到用戶的硬盤上,而是會成為用戶會話信息的一部分,關閉浏覽器或會話超時這個Cookie即會消失,這種Cookie稱作非永久性的 Cookie。存放SessionID的Cookie就是這樣的一種CookIE,它不存放在硬盤上,只存在內存之中。

  5. 將要發出的Cookie附加到Response的Cookies屬性中就可以將此Cookie發送到客戶端:Reponse.Cookies.Add(CookIE)

  6. Domain屬性+Path屬性 相同的所有Cookie 在客戶端都存在一個文件中,Cookie之間以”*”分割。每個Cookie的第一行是 Cookie 的名稱,第二行是值,第三行是Domain屬性+Path屬性組成的一個字符串,指示此Cookie的作用域,其余各行則包含 Cookie 的日常處理信息,例如過期日期和時間。Cookie 中還有一個簡單的校驗和,如果更改 CookIE 名稱或值的長度,浏覽器就會檢測到修改並刪除該 CookIE。

  二 讀取CookIE

  1. Request.Cookies 屬性中包含了客戶端發送到服務器的所有Cookie的集合,只有在請求URL的作用范圍內的CookIE才會被浏覽器連同Http請求一起發送到服務器。

  2. Name 和 Value 屬性和子鍵的值很容易讀到。

  3. Domain 和 Path 屬性 是讀不到的,讀Domain屬性永遠是””,讀Path屬性永遠是 ”/” 。本來這些屬性的用途很有限。如果您的頁面與 Cookie 不在相同的域,您根本就不會在頁面的位置接收到該 CookIE。

  4. 也無法讀取Cookie 的過期日期和時間。事實上,當浏覽器向服務器發送 CookIE 信息時,浏覽器並未將過期信息包括在內。您可以讀取 Expires 屬性,但總是返回為零的日期/時間值。Expires 屬性的主要作用是幫助浏覽器執行有關 Cookie 保存的日常管理。從服務器的角度來看,CookIE 要麼存在要麼不存在,所以對服務器而言,有效期並不是有用的信息。
所以,浏覽器在發送 Cookie 時並不提供此信息。如果您需要 CookIE 的過期日期,就必須重新設置。

  三 修改和刪除 CookIE

  1. 其實你不能直接修改一個Cookie,是創建一個同名的 Cookie,並把該 CookIE 發送到浏覽器,覆蓋客戶機上舊的 CookIE。

  2. 同樣您無法直接將其刪除一個Cookie,可以通過修改一個Cookie達到讓浏覽器幫你刪除Cookie的目的,修改CookIE的有效期為過去的某個時間,當浏覽器檢查 Cookie 的有效期時,就會刪除這個已過期的 CookIE。

  四 CookIE同Session的關系

  1. ASP.Net中Session可以采用cookie 和cookieless兩種方法,cookieless方式是將SessionID放在URL中在客戶端和服務端中來回傳遞,不需要用到cookIE,在這裡不討論這個方式。

  2. 在ASP.Net中客戶第一次請求一個URL,服務器給這個客戶生成一個SessionID,並以非永久性的 CookIE發送到客戶端。

  3. 非永久性的 CookIE只有在浏覽器關閉後這些CookIE才隨之消失,Session的超時判斷是這樣的過程:

  3.1 第一次客戶端訪問服務器,會得到一個SessionID,以非永久性的 CookIE發送到客戶端。

  3.2 在這個浏覽器關閉之前訪問這個URL,浏覽器都會把這個SessionID發送到服務端,服務端根據SessionID來維持對應此客戶的服務端的各種狀態(就是Session中保存的各種值),在web應用程序中可以對這些Session進行操作。

  3.3 服務端維護此SessionID的過期時間,IIS中可以設置Session的超時時間。每次請求都將導致服務端將此SessioID的過期時間延長一個設置的超時時間。

  3.4 當服務端發現某個SessionID已經過時,即某個客戶已經在設置的超時時間內沒有再次訪問此站點,即將此SessionID,連同跟此SessionID相關的所有Session變量刪除。

  3.5 客戶端的浏覽器未關閉前,並不知道服務端已經將這個SessionID刪除,客戶端依舊發送此SessionID的cookIE到服務端,只是此時的服務端已經不認識此SessionID了,會將此用戶當做新用戶,再次分配一個新的SessionID。 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved