在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不存在”);
    }
}
 
页面代码:
<:button id=”btnremovecookie” runat=”server” text=”删除cookie”
             />
<asp:button id=”btncheckcookie” runat=”server” text=”检查cookie”
             />

运行代码测试,你会发现,怎么点删除按钮,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的时候,描述得太不清楚了,给我们造成了不小的麻烦。

 

 

摘自 涂剑凯——在路上