ASP.NET Cookie对象到底是毛啊?(简单小例子)

时间:2024-03-24 16:03:32

记得刚接触asp.net的时候,就被几个概念搞的头痛不已,比如Request,Response,Session和Cookie。然后还各种在搜索引擎搜,各种问同事的,但是结果就是自己还是很懵的节奏。

那cookie到底是毛啊?下面是我最不喜欢的一种解释方式(官方定义吧应该叫,我这种智商根本读不懂嘛~)

Cookie对象也称缓存对象,该对象用于保存客户端浏览器请求的服务器页面,也可用它存放非敏感性的用户信息。

以前根本读不懂啊,现在其实也懵懵的。

还是用例子能把这个概念搞明白

1、做一个用户登录的界面,用cookies保存登录信息的功能。如图:

ASP.NET Cookie对象到底是毛啊?(简单小例子)

后台代码:

protected void Page_Load(object sender, EventArgs e)
{
if (Request.Cookies["password"] != null)
{
if (DateTime.Now.CompareTo(Request.Cookies["password"].Expires) > 0)
{
textbox_password.Text = Request.Cookies["password"].Value;
}
}
}
protected void button_login_Click(object sender, EventArgs e)
{
if (checkbox_remember.Checked)
{
HttpCookie cookie_password = new HttpCookie("password");
cookie_password.Value = textbox_password.Text;
Response.Cookies.Add(cookie_password); DateTime dtNow = DateTime.Now;
TimeSpan ts = new TimeSpan(0, 0, 0, 10);//这里是将cookie的有效期设置成10s
cookie_password.Expires = dtNow.Add(ts);
}
}

这个例子很简单,思路就是选择记住密码的checkbox,就创建一个cookie用于记录密码的内容,同时设置有效期。当下次加载的时候,判断有没有这个“密码”cookie,有的话判断这个cookie是否过期,若未过期,就将这个cookie里存的值取出来,放到对应的文本框中。

这里把有效期设置为10s的原因是为了让大家看到的效果明显些。大家只要不断的去刷新页面,就会发现在10s之前,密码部分还是一直有值,过了10s,就自动清空了。这就是因为cookie到期。

2、一个统计当前IP登录页面次数的功能。界面如图:

ASP.NET Cookie对象到底是毛啊?(简单小例子)

其实还是这个例子比较有意思,界面很简单,但是问题稍多。

后台代码:

        string ipAddress = string.Empty;
protected void Page_Load(object sender, EventArgs e)
{
ipAddress = Dns.GetHostByName(Server.MachineName.ToString()).AddressList[0].ToString();
if (!IsPostBack)
{
if (Request.Cookies.AllKeys.Contains(ipAddress))
{
//Request.Cookies[ipAddress].Value = (Convert.ToInt32(Request.Cookies[ipAddress].Value) + 1).ToString();@@@
HttpCookie cookie_ip = new HttpCookie(ipAddress);
cookie_ip.Value = (Convert.ToInt32(Request.Cookies[ipAddress].Value) + 1).ToString();
Response.Cookies.Set(cookie_ip);
}
else
{
HttpCookie cookie_ip = new HttpCookie(ipAddress);
cookie_ip.Value = "1";
Response.Cookies.Add(cookie_ip);
DateTime dtNow = DateTime.Now;
TimeSpan ts = new TimeSpan(0, 0, 0, 20);
cookie_ip.Expires = dtNow.Add(ts);
}
}
}
protected void button_statistics_Click(object sender, EventArgs e)
{
if (Request.Cookies[ipAddress] != null)
{
textbox_count.Text = Request.Cookies[ipAddress].Value;
}
else
{
textbox_count.Text = "0";
}
} protected void button_clear_Click(object sender, EventArgs e)
{
HttpCookie cookie_ip = new HttpCookie(ipAddress);
cookie_ip.Expires = DateTime.Now.AddDays(-1);
Response.Cookies.Set(cookie_ip);
Request.Cookies.Remove(ipAddress);
Request.Cookies.Clear();
}

这个小例子的思路就是,先获得本地的IP地址,这就保证了添加Cookie的时候,给Cookie了一个独一无二的key。在刷新页面的时候,去判断当前所有Cookie中是否存在一个同名的cookie。如果不存在,就新建一个cookie,当然,此cookie的key=IP地址。就是Page_Load里else的部分。如果存在,那么就在原来的值的基础上加1。这里要注意修改已存在Cookie值的写法。

最开始的时候我用的是注释掉的@@@这行代码,就是正常思路,看着也没什么问题呀,不过这样写不行,第一次加载之后的每次加载,取到的Request.Cookies[ipAddress].Value这个值总是1。所以对于修改已有的cookie值,还是需要使用cookies的set方法才行。

此外还有一个地方是需要注意的,就是删除cookie的时候,如果直接使用Cookies.Remove或者Cookies.Clear()方法都达不到想要的效果。需要配合的加上Expires,给一个负值。然后去更新Cookie,再删除,这样这个cookie就彻底消失了。否则在下次加载的时候又会出现,这个还真不知道是为什么?我之前就写了一句Request.Cookies.Clear(),打断点跟的时候,所有的cookie确实都清空了,但是当再次加载的时候,在添加cookie前打了断点,会发现之前删除的cookie又出现了。很奇怪啊~~

希望明白的朋友告诉一声怎么回事哈。

两个简单的小例子让自己对cookie不再感觉那么陌生和害怕了。所以光看概念还是效果一般,动手才是王道呀~