ASP.NET Cookie对象到底是毛啊?(简单小例子)
记得刚接触asp.net的时候,就被几个概念搞的头痛不已,比如Request,Response,Session和Cookie。然后还各种在搜索引擎搜,各种问同事的,但是结果就是自己还是很懵的节奏。
那cookie到底是毛啊?下面是我最不喜欢的一种解释方式(官方定义吧应该叫,我这种智商根本读不懂嘛~)
Cookie对象也称缓存对象,该对象用于保存客户端浏览器请求的服务器页面,也可用它存放非敏感性的用户信息。
以前根本读不懂啊,现在其实也懵懵的。
还是用例子能把这个概念搞明白
1、做一个用户登录的界面,用cookies保存登录信息的功能。如图:
后台代码:
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登录页面次数的功能。界面如图:
其实还是这个例子比较有意思,界面很简单,但是问题稍多。
后台代码:
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不再感觉那么陌生和害怕了。所以光看概念还是效果一般,动手才是王道呀~
新浪微博:http://weibo.com/zhouhongyu1989 欢迎围观~!
本文出自 “给我一根儿烟” 博客,请务必保留此出处http://zhouhongyu1989.blog.51cto.com/2931598/1439810
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。