在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的時候,描述得太不清楚了,給我們造成了不小的麻煩。
