主頁 > 知識(shí)庫 > 巧用ASP.NET Cookie

巧用ASP.NET Cookie

熱門標(biāo)簽:塔城代理外呼系統(tǒng) 400電話辦理哪家性價(jià)比高 遂寧市地圖標(biāo)注app 地圖定位圖標(biāo)標(biāo)注 地圖標(biāo)注專業(yè)團(tuán)隊(duì) 地圖標(biāo)注的公司有哪些 代理接電話機(jī)器人如何取消 天心智能電銷機(jī)器人 濮陽外呼電銷系統(tǒng)怎么樣

先看一看cookie學(xué)習(xí)圖,看一看學(xué)什么?

一、Cookie是什么

Cookie是一小段文本信息,存在客戶端硬盤上的長度不超過4KB的文本文件。
伴隨著用戶請(qǐng)求和頁面在Web服務(wù)器和瀏覽器之間傳遞
用戶每次訪問站點(diǎn)時(shí),Web應(yīng)用程序都可以讀取Cookie包含的信息。

二、工作原理

由于HTTP是一種無狀態(tài)的協(xié)議,服務(wù)器單從網(wǎng)絡(luò)連接上無從知道客戶身份。怎么辦呢?就給客戶端們頒發(fā)一個(gè)通行證吧,每人一個(gè),無論誰訪問都必須攜帶自己通行證。這樣服務(wù)器就能從通行證上確認(rèn)客戶身份了。這就是Cookie的工作原理。
Cookie實(shí)際上是一小段的文本信息??蛻舳苏?qǐng)求服務(wù)器,如果服務(wù)器需要記錄該用戶狀態(tài),就使用response向客戶端瀏覽器頒發(fā)一個(gè)Cookie??蛻舳藶g覽器會(huì)把Cookie保存起來。當(dāng)瀏覽器再請(qǐng)求該網(wǎng)站時(shí),瀏覽器把請(qǐng)求的網(wǎng)址連同該Cookie一同提交給服務(wù)器。服務(wù)器檢查該Cookie,以此來辨認(rèn)用戶狀態(tài)。服務(wù)器還可以根據(jù)需要修改Cookie的內(nèi)容。

 

三、Cookie對(duì)象的屬性和方法
屬性:

(1).Name:獲取或設(shè)置Cookie的名稱
(2).Value:獲取或設(shè)置Cookie的值
(3).Expires:獲取或設(shè)置Cookie的過期時(shí)間
(4).Version:獲取或設(shè)置Cookie的符合HTTP維護(hù)狀態(tài)的版本

方法:
(1).Add:增加Cookie變量,將指定的cookie保存到Cookies集合中
(2).Clear:清除Cookie集合中變量
(3).Get:通過變量名或索引得到Cookie變量的值
(4).Remove:通過Cookie變量名或索引刪除Cookie對(duì)象

四、優(yōu)缺點(diǎn)

優(yōu)點(diǎn):
相比Session和Application對(duì)象,使用Cookie能持久化保存用戶信息。Cookie保存在客戶端,而Session和Application保存在服務(wù)器端,故Cookie能長久保存。web應(yīng)用程序可以通過獲取客戶端的Cookie來進(jìn)行用戶身份認(rèn)證。
Asp.net包含兩個(gè)Cookie集合,通過HttpRequest的Cookie集合進(jìn)行訪問,Cookie不是Page類的子類,所以使用方法與Session和Application不同,相比于他們Cookie的優(yōu)點(diǎn)如下:
1.可以配置過期時(shí)間
2.簡(jiǎn)單:Cookie是一種基于文本的輕量級(jí)結(jié)構(gòu),包括簡(jiǎn)單的鍵值對(duì)
3.數(shù)據(jù)持久:因?yàn)楸4娴娇蛻舳?br /> 4.無任何服務(wù)器資源:因?yàn)榇鎯?chǔ)在本地客戶端

缺點(diǎn)如下:
1.大小限制:
2.不確定性:可能用戶刪除Cookie或者禁用
3.安全風(fēng)險(xiǎn):可偽造修改

五、注意什么?
[1].使用Cookie保存客戶端瀏覽器請(qǐng)求服務(wù)器頁面的請(qǐng)求信息時(shí),保存時(shí)間的長短取決于Cookie對(duì)象的Expires屬性,可以根據(jù)需要來設(shè)置。若未設(shè)置Cookie的失效日期,則它們僅保存到關(guān)閉瀏覽器為止。若將Cookie對(duì)象的Expires屬性設(shè)置為DateTime.MaxValue,則表示Cookie永遠(yuǎn)不會(huì)過期。

[2].Cookie存儲(chǔ)的數(shù)據(jù)量有所限制,大多數(shù)瀏覽器支持的最大容量為4096字節(jié),因此不要用Cookie來保存大量數(shù)據(jù)。

[3].  并非所有瀏覽器都支持Cookie,并且數(shù)據(jù)是以明文形式保存在客戶端計(jì)算機(jī)中,因此最好不要用Cookie來保存敏感的未加密數(shù)據(jù)。

[4].在ASP.NET中有兩個(gè)Cookies集合,即:Response對(duì)象的Cookies集合和Request對(duì)象的Cookies集合,但兩者的作用有所不同,通過前者可以將Cookie寫入客戶端,通過后者可以讀取存儲(chǔ)在客戶端的Cookie。
接下來講到Cookie的實(shí)際應(yīng)用。

首先建立如圖所示的界面,通過該界面可登錄到某個(gè)網(wǎng)站,具體要求如下:

  •      在首次登錄后,將登錄信息寫入到用戶計(jì)算機(jī)的Cookie中;
  •      當(dāng)再次登錄時(shí),將用戶計(jì)算機(jī)中的Cookie信息讀出并顯示,以備用戶選擇使用;
  •      可以利用讀出Cookie中的信息來直接登錄網(wǎng)站。

操作步驟

1、在VS新建一個(gè)的空白的asp.net應(yīng)用程序,在項(xiàng)目管理器中,添加一個(gè)Web窗體;使用一個(gè)2行3列的表格進(jìn)行布局;布局結(jié)束后,將2個(gè)Label控件分別置于布局表格的左側(cè),分別將其Text屬性設(shè)置為用戶名和密碼,在布局表格中添加兩個(gè)TextBox控件、一個(gè)Button控件和一個(gè)CheckBox控件,將Button控件的Text屬性設(shè)置為“登錄”,將CheckBox控件的Text屬性設(shè)置為“記住用戶名和密碼”。

2、添加一個(gè)HTML頁面

    將默認(rèn)將名稱改為login.html

3、編寫事件處理代碼

span style="font-family:KaiTi_GB2312;font-size:18px;">protected void Button1_Click(object sender, EventArgs e) 
    { 
 
      if (CheckBox1.Checked) 
      { 
        Response.Cookies["ID"].Expires = new DateTime(2016, 2, 24); //用鍵名為ID的Cookie設(shè)置生存時(shí)間 
        Response.Cookies["PW"].Expires = new DateTime(2016, 2, 24); 
        Response.Cookies["ID"].Value = TextBox1.Text; //將鍵名為ID的Cookie的值設(shè)置為文本框內(nèi)容 
        Response.Cookies["PW"].Value = TextBox2.Text; 
      } 
      Response.Redirect("Login.html");  
 
    }/span>

首先判斷該頁面定義的Cookie是否為空,若不為空則將Cookie中的內(nèi)容讀出并置于TextBox1和TextBox2兩個(gè)文本框中,這樣用戶在自己機(jī)器上第二次登錄同一個(gè)頁面時(shí),直接單擊【登錄】按鈕即可,省掉了再次輸入用戶ID和密碼的過程

span style="font-family:KaiTi_GB2312;font-size:18px;"> protected void Page_Load(object sender, EventArgs e) 
    { 
      if (Request.Cookies["ID"] != null  Request.Cookies["PW"] != null) 
      { 
        TextBox1.Text = Request.Cookies["ID"].Value.ToString(); 
        TextBox2.Text = Request.Cookies["PW"].Value.ToString();//將鍵名為ID的Cookie的值讀出,并在文本框TextBox2中顯示出來 
      } 
 
    }/span> 

當(dāng)再次加載頁面的時(shí)候就會(huì)出現(xiàn)如下圖所示。

 

上面只是簡(jiǎn)單的展示了幾個(gè)比較常見的功能(保留用戶個(gè)人信息,如姓名、密碼等,幫助用戶快速登錄網(wǎng)頁),還有很多未知的功能讓我們?nèi)ヌ剿?br /> 例如:

  •       保存用戶的個(gè)人愛好,設(shè)計(jì)者可根據(jù)Cookie中記錄的用戶愛好來設(shè)置網(wǎng)站的風(fēng)格;
  •       進(jìn)行在線購物時(shí),記錄用戶購買的商品信息;
  •       記錄彈出窗口被彈出的狀況,一些頁面被打開時(shí)會(huì)彈出通知或廣告窗口,可以使用Cookie記錄窗口被彈出的情況,了解彈出窗口是否被彈出過,若被彈出過,再次打開頁面時(shí)就不再彈出該彈出窗口。

通過敲這個(gè)例子讓我更加深入的了解了Cookie是如何用的,以前看到這這種類似的文章都躲著不看,感覺肯定難得不行,但是自己嘗試后才知道,其實(shí)一點(diǎn)都不難,所以學(xué)習(xí)一定不要怕困難。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,大家共同進(jìn)步!

您可能感興趣的文章:
  • asp.net清空Cookie的兩種方法
  • asp.net cookie清除的代碼
  • asp.net cookie的操作,寫入、讀取與操作
  • asp.net(C#)跨域及跨域?qū)慍ookie問題
  • asp.net中的cookie使用介紹
  • asp.net關(guān)于Cookie跨域(域名)的問題
  • Asp.net內(nèi)置對(duì)象之Cookies(簡(jiǎn)介/屬性方法/基本操作及實(shí)例)
  • asp.net Cookie值中文亂碼問題解決方法
  • asp.net中使用cookie與md5加密實(shí)現(xiàn)記住密碼功能的實(shí)現(xiàn)代碼

標(biāo)簽:麗江 宜春 重慶 汕頭 河南 婁底 本溪 吉林

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《巧用ASP.NET Cookie》,本文關(guān)鍵詞  巧用,ASP.NET,Cookie,巧用,ASP.NET,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《巧用ASP.NET Cookie》相關(guān)的同類信息!
  • 本頁收集關(guān)于巧用ASP.NET Cookie的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章