如何進(jìn)行C# Cookie編程
Cookie就是所謂的" 小甜餅" ,他最早出現(xiàn)是在Netscape Navigator .0中。Cookie其實(shí)就是由Web服務(wù)器創(chuàng)建的、將信息存儲(chǔ)在計(jì)算機(jī)上的文件。那么為什么Web服務(wù)器要在客戶機(jī)上面創(chuàng)建如此文件?這是因?yàn)楫?dāng)客戶機(jī)發(fā)送一個(gè)請(qǐng)求到WEB服務(wù)器時(shí)(譬如準(zhǔn)備瀏覽面時(shí)),無(wú)論此客戶機(jī)是否是第一次來(lái)訪,服務(wù)器都會(huì)把它當(dāng)作第一次來(lái)對(duì)待,WEB服務(wù)器所做的工作只是簡(jiǎn)單的進(jìn)行響應(yīng),然后就關(guān)閉與該用戶的連接。這樣處理過(guò)程所帶來(lái)的缺點(diǎn)時(shí)顯而易見(jiàn)的。自從網(wǎng)景公司開(kāi)發(fā)出Cookie以后,就可以利用Cookie來(lái)保存用戶的識(shí)別信息。Cookie的作用可以記錄了您在該站點(diǎn)上曾經(jīng)訪問(wèn)過(guò)的面,由此幫助您下次訪問(wèn)該站點(diǎn)時(shí)自定義查看。Cookies 也可以存儲(chǔ)個(gè)人可識(shí)別信息。個(gè)人可識(shí)別信息是可以用來(lái)識(shí)別或聯(lián)系您的信息,例如姓名、電子郵件地址、家庭或工作地址,或者電話號(hào)碼。然而,網(wǎng)站只能訪問(wèn)您提供的個(gè)人可識(shí)別信息。例如,除非您提供電子郵件名稱,否則網(wǎng)站將不能確定您的電子郵件名稱。另外,網(wǎng)站不能通過(guò)Cookie來(lái)訪問(wèn)計(jì)算機(jī)上的其他信息。當(dāng)然除非你提供。那么Cookie到底存放在什么地方?如果機(jī)器的系統(tǒng)是視窗98且安裝在" C" 盤中,那么Cookie存放在" C:\Windows\Cookies" 目錄中;如果機(jī)器系統(tǒng)是視窗000且安裝在" C" 盤中,那么Cookie存放在" C:\Documents and Settings\Administrator\Cookies" 目錄中。了解了Cookie這么多知識(shí),我們還是來(lái)了解一下本文的重點(diǎn)-- C#是如何進(jìn)行Cookie方面編程的。主要內(nèi)容有二點(diǎn):其一是 C#是如何寫入Cookie;其二是 C#是如何訪問(wèn)自己寫入的Cookie。
一、本文介紹C# Cookie編程的程序設(shè)計(jì)和運(yùn)行的軟件環(huán)境
微軟公司視窗000服務(wù)器版
.Net FrameWork SDK Beta
C#進(jìn)行Cookie方面編程是通過(guò)ASP.NET面來(lái)實(shí)現(xiàn)的。
二、C#如何寫入Cookie
為了寫入Cookie,他的步驟主要有三步,具體如下:
首先就要?jiǎng)?chuàng)建一個(gè)HttpCookie對(duì)象,通過(guò)這個(gè)對(duì)象來(lái)構(gòu)造一個(gè)Cookie,這個(gè)對(duì)象的名稱就是以后產(chǎn)生的Cookie名稱。具體如下代碼:
- HttpCookie cookie = new HttpCookie ( " 用戶定義的Cookie名稱" ) ;
然后對(duì)創(chuàng)建的HttpCookie對(duì)象的" Value" 屬性分配一個(gè)字符串值," Value" 的值就是后來(lái)產(chǎn)生的Cookie的值。具體代碼如下:
cookie.Value = "用戶給Cookie賦值" ; 如果你想寫入的Cookie數(shù)值不是一個(gè)簡(jiǎn)單的字符串,而是一個(gè)復(fù)雜的數(shù)據(jù)類型,我們知道這些數(shù)據(jù)類型是不能直接存貯到Cookie中的,因?yàn)镃ookie中只能存貯字符串。但你可以通過(guò)一個(gè)變通的方法,就是把這個(gè)復(fù)雜的數(shù)據(jù)類型轉(zhuǎn)換成多個(gè)字符串,然后把這多個(gè)字符串同時(shí)賦值給產(chǎn)生的Cookie值,這樣Cookie中的內(nèi)容就豐富了,以后利用Cookie完成的功能也強(qiáng)大了。這時(shí)你可能就會(huì)明白為什么當(dāng)你瀏覽Web服務(wù)器,Web服務(wù)器會(huì)知道你什么時(shí)候曾經(jīng)瀏覽過(guò),并且曾經(jīng)待過(guò)多長(zhǎng)時(shí)間等信息了。因?yàn)檫@些信息已經(jīng)存儲(chǔ)到你第一次瀏覽面時(shí),Web服務(wù)器產(chǎn)生的Cookie中去了。下列代碼是把多個(gè)字符串存儲(chǔ)到Cookie的例子:
- cookie [ " 姓名" ] = " 王天";
- cookie [ " 性別" ] = " 男";
- cookie [ " 年齡" ] = " 6";
Cookie有臨時(shí)的,也有永遠(yuǎn)的。永久 Cookie 以文件形式存儲(chǔ)在計(jì)算機(jī)上,關(guān)閉 Internet Explorer 時(shí)仍然保留在計(jì)算機(jī)上。再次訪問(wèn)該站點(diǎn)時(shí),創(chuàng)建該 Cookie 的網(wǎng)站可以讀取。在具體的編程時(shí)候,是在寫入此Cookie的時(shí)候,設(shè)定Cookie的生命周期,具體如下代碼:
- DateTime dtNow = DateTime . Now ;
- TimeSpan tsMinute = new TimeSpan ( 0 , , 0 , 0 ) ;
- cookie . Expires = dtNow + tsMinute ;
以上代碼是設(shè)定產(chǎn)生的Cookie的生命期為" 一個(gè)小時(shí)" ,你可以通過(guò)修改" TimeSpan" 屬性來(lái)設(shè)定產(chǎn)生Cookie的具體生命期。
.最后調(diào)用" Response.Cookies" 對(duì)象的" Add()" 方法,加入此對(duì)象,這樣就可以產(chǎn)生一個(gè)Cookie了。具體代碼如下:
- Response . Cookies . Add ( cookie ) ;
- 下列代碼就是在 C#寫入Cookie的完整代碼(Write.aspx):
- < % @ language = "C#" %>
- < script runat = "server" >
- void WriteClicked ( Object Sender , EventArgs e )
- {
- //創(chuàng)建一個(gè)HttpCookie對(duì)象
- HttpCookie cookie = new HttpCookie ( NameField . Text ) ;
- //設(shè)定此cookies值
- cookie . Value = ValueField . Text ;
- //設(shè)定cookie的生命周期,在這里定義為一個(gè)小時(shí)
- DateTime dtNow = DateTime . Now ;
- TimeSpan tsMinute = new TimeSpan ( 0 , , 0 , 0 ) ;
- cookie . Expires = dtNow + tsMinute ;
- cookie [ "姓名" ] = "王天" ;
- cookie [ "性別" ] = "男" ;
- cookie [ "年齡" ] = "6" ;
- //加入此cookie
- Response . Cookies . Add ( cookie ) ;
- Response . Write ( NameField . Text + "Cookie創(chuàng)建完畢 < br > < hr > " ) ;
- }
- < /script >
- < html >
- < body >
- < h > 在 C#面中創(chuàng)建cookie < /h >
此cookie的生命周期定義為一個(gè)小時(shí)
- < form runat="server">
- Cookie名稱:< asp:textbox id = "NameField" runat = "server" /> < br >
- Cookie的值:< asp:textbox id = "ValueField" runat = "server" /> < br >
- < asp:button text = "創(chuàng)建Cookie" onclick = "WriteClicked" runat = "server" /> < br >
- < /form >
- < /body >
- < /html >
當(dāng)然上面的代碼產(chǎn)生的Cookie在內(nèi)容上面有點(diǎn)單調(diào)了。其實(shí)對(duì)于內(nèi)容十分豐富的Cookie來(lái)說(shuō),他還有許多屬性,充分的利用這些屬性,才可以利用了Cookie的強(qiáng)大功能。下表是Cookie的一些常用的屬性:
屬性 描述
Domain 設(shè)定/獲得Cookie應(yīng)屬于的域名。一旦設(shè)定了此屬性,則只限定于此域名的Web服務(wù)器訪問(wèn)此Cookie??梢栽O(shè)定為"ccw.com.cn"
Path 設(shè)定/獲得Cookie應(yīng)屬于的路徑,如果設(shè)定后,則訪問(wèn)此Cookie的Web面則被限定在此路徑里面。其他路徑的Web面則不能訪問(wèn)。
Secure 設(shè)定/獲得一個(gè)標(biāo)識(shí)來(lái)表明利用HTTP協(xié)議是否能夠安全的傳輸Cookie到客戶端的瀏覽器。
HasKeys 表明是否此Cookie是否是多個(gè)字符串組成的。
在寫入Cookie的時(shí)候,最大限度的利用這些屬性,對(duì)于最大程度的利用寫入的Cookie是十分重要的。
三、C#是如何讀取已產(chǎn)生的Cookie
讀取指定的Cookie比起寫入Cookie要來(lái)的容易的多了,只需要使用" Request.Cookies" 對(duì)象就可以完成。下面是讀取指定Cookie名稱的方法:
- HttpCookie cookie = Request.Cookies [ " Cookie的名稱" ] ;
下面是顯示已經(jīng)讀取了的Cookie的數(shù)值:
- Response.Write (cookie . Value . ToString ( ) ) ;
掌握了上面的要點(diǎn),讀取Cookie就顯得非常容易了,下列是讀取Cookie的程序代碼(read.aspx):
- < % @ language = "C#" %>
- < script runat = "server" >
- void ReadClicked ( Object Sender , EventArgs e )
- {
- //得到用戶輸入的cookie名稱
- String strCookieName = NameField . Text ;
- //獲得cookie
- HttpCookie cookie = Request.Cookies [ strCookieName ] ;
- //確定是否存在用戶輸入的cookie
- if ( null == cookie ) {
- Response.Write ( "沒(méi)有發(fā)現(xiàn)指定的cookie < br > < hr > " ) ;
- }
- else {
- //找到指定的cookie,顯示cookie的值
- String strCookieValue = cookie . Value . ToString ( ) ;
- Response.Write ( strCookieName + " cookie 的值為: < b > "
- + strCookieValue + " < /b > < br > < hr > " ) ;
- }
- }
- < /script >
- < html >
- < body >
- 在 C#面中讀取指定Cookie值< br >
- < form runat = "server" >
- 請(qǐng)輸入要讀取的Cookie名稱:< asp:textbox id = "NameField" runat = "server" />
- < asp:button text = "讀取cookie" onclick = "ReadClicked" runat = "server" />
- < /form >
- < /body >
- < /html >
四、總結(jié)
至此我們已經(jīng)介紹了用C# Cookie編程的大部分內(nèi)容。其實(shí)Cookie在互聯(lián)網(wǎng)上有著比較大的作用。譬如它可讓W(xué)EB站點(diǎn)跟蹤特定訪問(wèn)者的訪問(wèn)次數(shù)、最后訪問(wèn)時(shí)間和訪問(wèn)者進(jìn)入站點(diǎn)的路徑等;還可告訴在線廣告商廣告被點(diǎn)擊的次數(shù),從而可以更精確的投放廣告;它可讓用戶在不鍵入密碼和用戶名的情況下進(jìn)入曾經(jīng)瀏覽過(guò)的一些站點(diǎn);最為重要的是它可幫助站點(diǎn)統(tǒng)計(jì)用戶資料以實(shí)現(xiàn)個(gè)性化服務(wù)等等。掌握了C# Cookie編程,就可以在程序中充分利用Cookie來(lái)實(shí)現(xiàn)上面的這些功能了。不信你試一試。
【編輯推薦】