在web開發中Cookie是必不可少的
.NET自然也有一個強大的Cookie操作類,我們用起來也非常方便,不過在使用中我們會發現一個坑爹的事情Response.Cookies.Remove刪除不了Cookie。
例子如下:
protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { HttpCookie UserInfo = new HttpCookie("UserInfo"); UserInfo.Value = "bdstjk"; Response.Cookies.Add(UserInfo); } } protected void btnRemoveCookie_Click(object sender, EventArgs e) { Response.Cookies.Remove("UserInfo"); Response.Write("<script type=\"text/javascript\">alert(\"刪除Cookie成功!\");</script>"); } protected void btnCheckCookie_Click(object sender, EventArgs e) { if (Request.Cookies["UserInfo"] != null) { Response.Write("Cookie存在,"+Request.Cookies["UserInfo"].Value); } else { Response.Write("Cookie不存在"); } }
頁面代碼:
<asp:Button ID="btnRemoveCookie" runat="server" Text="刪除Cookie" onclick="btnRemoveCookie_Click" /> <asp:Button ID="btnCheckCookie" runat="server" Text="檢查Cookie" onclick="btnCheckCookie_Click" />
運行代碼測試,你會發現,怎么點刪除按鈕,cookie都存在,如下圖:
這是為什么呢?明明是執行了刪除cookie的操作,為什么就是刪不掉呢?
我們去看看.NET的HttpCookieCollection實現源碼
public void Remove(string name) { if (this._response != null) { this._response.BeforeCookieCollectionChange(); } this.RemoveCookie(name); if (this._response != null) { this._response.OnCookieCollectionChange(); } }
這個操作在HttpCookieCollection這個集合里面刪除了cookie,當服務器將數據傳輸到客戶端的時候,不會包含這個已經在服務端刪除了的Cookie的任何信息,瀏覽器也就不會對它做任何改變(remove方法只是不讓服務器向客戶機發送那個被刪除的cookie,與此cookie留不留在客戶機里無關)。所以cookie刪除不掉的情況就出現。
那么如果我們想刪除cookie應該怎么做呢?
把刪除cookie的代碼改成如下語句:
if (Request.Cookies["UserInfo"] != null) { Response.Cookies["UserInfo"].Expires = DateTime.Now.AddDays(-1); } Response.Write("<script type=\"text/javascript\">alert(\"刪除Cookie成功!\");</script>");
我們再運行程序,測試:
好了。Cookie已經刪除。通過設置Cookie的過期時間為負,強制使Cookie過期。就能實現我們需要的效果了。
既然Response.Cookies.Remove沒有辦法實現我們需要的效果,為什么微軟還有留着呢,因為CookieCollection實現ICollection接口,romove是必須實現的方法,盡管它沒多大的實際價值。而集合的romove也應該是這樣的實現方式,只不過微軟在寫MSDN的時候,描述得太不清楚了,給我們造成了不小的麻煩。