asp.net cookie的使用.
Cookie就是服务器暂时存放在你的电脑里的资料(.txt格式的文本文件),好让服务器用来辨认你的计算机。当你在浏览网站的时候,Web服务器会先送一小小资料放在你的计算机上,Cookies 会帮你在网站上所打的文字或是一些选择都记录下来。当下次你再访问同一个网站,Web服务器会先看看有没有它上次留下的Cookies资料,有的话,就会依据Cookie里的内容来判断使用者,送出特定的网页内容给你。
cookie的限制:必须通过浏览器操作,如果浏览器禁用cookie,则无法工作;信息只能是文本,大小限制在4kb。
实现单值的cookie设置:
首先在页面中添加一个按钮和文本
在按钮的提交事件中,将cookie值写到客户端
protected void Button1_Click(object sender, EventArgs e) { HttpCookie ck_1 = new HttpCookie("animal");//声明一个名称为animal的cookie ck_1.Value = "猫"; ck_1.Expires = DateTime.Now.AddDays();//设置这个cookie在一天后过期,如果不设置过期时间,那么在浏览器关闭后cookie失效。 Response.Cookies.Add(ck_1);//发送写入cookie指令给浏览器 }
在页面的load方法中读取cookie
protected void Page_Load(object sender, EventArgs e) { if(Request .Cookies ["animal"]!=null) { Label1.Text = "读取的cookie值为:" + Request.Cookies["animal"].Value; } }
运行程序,页面出来后点击按钮,这时会将cookie写到客户端。然后再点击一次按钮,当程序执行load方法的时候就能读取cookie值了。但是却是乱码
但是,结束调试,再次运行程序进入这个页面的时候,就没有乱码了。这可能是因为编码和解码不一致造成的,因此用ck_1.Value = Server.UrlEncode("猫");这种方式来编码,同时,用Server.UrlDecode(Request.Cookies["animal"].Value)来解码。但是这样在运行程序后,点击一次按钮将cookie写到客户端,再点第二次按钮的时候,程序似乎并没有找到这个cookie。然后从新调试,这时页面就找到这个cookie了,但是你刷新页面,在代码中仍然表示没有找到这个cookie,即这个cookie为null。每次都是要重新启动调试才能获取这个cookie。这个问题的原因似乎是一个时间间隔,就是说,当页面打开后,通过load方法获取了这个cookie值,但是要隔一段时间,你再来刷新页面的时候,就能获取这个cookie的值,如果你是连续两次的刷新获取这个cookie值,就不行。当然,你如果在load方法中用两行代码来获取同一个cookie还是可以获取的。
因此代码中的if(Request .Cookies ["animal"]!=null)这个判断就显得非常重要了,这样可以避免页面在第一次加载完成,获取了cookie的值以后,紧接着又刷新了一次页面反而导致页面的显示结果不对。
实现单值cookie信息删除:
由于cookie是存放在客户端硬盘的,因此不能像删除变量值那样,这需要将cookie的有效期Expires设置为一个过期的日期。标准写法是
Response.Cookies["animal"].Expires = DateTime.MinValue;
对于同类型的信息可以保存在一个cookie中,这样就可以使得这些信息管理起来比较容易,最主要的是有相同的有效期。
以下示例显示了编写同一 Cookie 的两种不同方法,其中的每个 Cookie 都带有两个子键: Response.Cookies("userInfo")("userName") = "mike" Response.Cookies("userInfo")("lastVisit") = DateTime.Now.ToString Response.Cookies()
HttpCookie ) Response.Cookies.Add(aCookie)
多值cookie结构:
[主键名称]
[子键名称]:[子键值]
[子键名称2]:[子键值2]
[子键名称3]:[子键值3]
[主键名称2]
[子键名称]:[子键值]
[子键名称2]:[子键值2]
[子键名称3]:[子键值3]
下面的代码演示了如何添加多值的cookie
protected void Button1_Click(object sender, EventArgs e) { HttpCookie ck_1 = new HttpCookie("people"); ck_1.Values.Add("name", "小王"); ck_1.Values.Add("); ck_1.Values.Add("sex", "男"); ck_1.Expires = DateTime.Now.AddDays(); Response.Cookies.Add(ck_1); ck_1 = new HttpCookie("student"); ck_1.Values.Add("name", "小赵"); ck_1.Values.Add("); ck_1.Values.Add("sex", "女"); ck_1.Expires = DateTime.Now.AddDays(); Response.Cookies.Add(ck_1); Label1.Text += Request.Cookies["people"].Values["name"]; Label2.Text += Request.Cookies["people"].Values["sex"]; Label3.Text += Request.Cookies["people"].Values["age"]; HttpCookie ck = Request.Cookies["student"]; Label4.Text += ck.Values["name"]; Label5.Text +=ck.Values["age"]; Label6.Text += ck.Values["sex"];
}
多值cookie的主键删除与清除单值cookie完全相同,Response.Cookies["people"].Expires = DateTime.MinValue;
另外一种非标准的写法:ck=response.cookie["keyname"]这样会在会话期间,保留一个没有value的空key。
对子键的修改:
protected void Page_Load(object sender, EventArgs e) { HttpCookie ck = Request.Cookies["student"]; Label4.Text += ck.Values["name"]; Label5.Text += ck.Values["age"]; Label6.Text += ck.Values["sex"]; } protected void Button2_Click(object sender, EventArgs e) { HttpCookie ck = Request.Cookies["student"]; ck.Values.Set("name", "小红");//对多值cookie的修改用的是set,而对单值cookie的修改用add Label4.Text += ck.Values["name"]; }
如上面的代码,当网页加载完成后,文本中能正常显示student cookie中的值,但是问题出在,当网页加载完成后,点击按钮来修改这个cookie,却发现这个cookie是null。根本没法获取,但是在过一段时间后才点击按钮,就能正常获取这个cookie了,这中间有一段时间间隔。
删除一个子键:
ck.values.remove("keyName");
删除全部子键:ck.values.clear();
asp.net cookie的使用.的更多相关文章
- 【转】asp.net Cookie值中文乱码问题解决方法
来源:脚本之家.百度空间.网易博客 http://www.jb51.net/article/34055.htm http://hi.baidu.com/honfei http://tianminqia ...
- ASP.NET Cookie 概述【转】
来源:http://msdn.microsoft.com/zh-cn/library/ms178194(VS.80).aspx ASP.NET Cookie 概述 Cookie 提供了一种在 Web ...
- How to secure the ASP.NET_SessionId cookie? 设置ASP.NET_SessionId Secure=true
How to secure the ASP.NET_SessionId cookie? To add the ; secure suffix to the Set-Cookie http header ...
- ASP.NET Cookie是怎么生成的
ASP.NET Cookie是怎么生成的 可能有人知道Cookie的生成由machineKey有关,machineKey用于决定Cookie生成的算法和密钥,并如果使用多台服务器做负载均衡时,必须指定 ...
- ASP.NET Cookie(一)--基本应用
Cookie提供了一种在Web应用程序中存储用户特定信息的方法.例如,当用户访问您的站点时,您可以使用Cookie存储用户首选项或其他信息.当该用户再次访问您的网站时,应用程序便可以检索以前存储的信息 ...
- asp.net,cookie,写cookie,取cookie
Cookie是一段文本信息,在客户端存储 Cookie 是 ASP.NET 的会话状态将请求与会话关联的方法之一.Cookie 也可以直接用于在请求之间保持数据,但数据随后将存储在客户端并随每个请求一 ...
- 对ASP.NET Cookie的一些新的认识
做用户登录,我一直用form验证的方式.有时候,为了节省时间,用户希望用户名输入框能够记住用户名,省得下次重新输入.这个时候光用form验证是不行的,因为form验证的话,用户一退出系统就失效了,所以 ...
- asp中cookie欺骗/注入原理与防范
一直以来sql注入被广泛关注,也有专门的防注系统代码.发现,如果代码不严谨也会有cookie欺骗/注入的情况.原来, 防注入系统没有注意到 Cookies 的问题!这里以ASP为例,分析一下cook ...
- ASP.NET Cookie对象到底是毛啊?(简单小例子)
记得刚接触asp.net的时候,就被几个概念搞的头痛不已,比如Request,Response,Session和Cookie.然后还各种在搜索引擎搜,各种问同事的,但是结果就是自己还是很懵的节奏. 那 ...
- Asp.Net Cookie的清除
背景 最近做到一个asp.net项目,项目中保存用户信息用到了cookie,因此,在注销身份的时候,就需要清除掉cookie. 探索过程 我先是试验了这种代码,在没有特殊声明前,代码都是写在Page_ ...
随机推荐
- Jvm垃圾回收堆内存变化过程
当Eden区域满时,触发minor GC,垃圾收集器把Eden区域中的不可达对象标记出来.第一次执行minor GC时Survivor 1与Survivor 2均为空: Eden中的不可达对象占用的内 ...
- css设置
box-size允许您以特定的方式定义匹配某个区域的特定元素. content-box(默认):宽度和高度分别应用到元素的内容框.在宽度和高度之外绘制元素的内边距和边框.border-box:为元素设 ...
- C#中Func<T,TResult>的用法和Lambda表达式
在C#3.0中引用了Limbda表达式,Limbda表达式实际上就是一个方法,只不过该方法是匿名方法(即没有名称的方法)代码片段: Func<int,string,string> t=(i ...
- MySTLString
auto ptr = new char[10]; delete ptr; delete 一个动态数组不能直接delete ptr, 应该是 delete[] ptr;
- C# 与MySQL
1. MySQL.Data.dll http://files.cnblogs.com/files/lwngreat/MySql.Data.rar 2.在工程中添加引用 3. 使用 Mys ...
- MySQL数据库改名字
在这里首先感谢那个网上已经给出了解决办法的同志 有很多MySQL数据库的初学者可能都会遇到一个关于改名字的问题,可能大家第一时间就会想到去网上搜搜,其实我跟大家的心理是一样的(呵呵). 据我所知,My ...
- More is better--hdu1856(并查集)
More is better Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 327680/102400 K (Java/Others) ...
- 计算机模拟(hd1283)
最简单的计算机 Problem Description 一个名叫是PigHeadThree的研究组织设计了一台实验用的计算机,命名为PpMm.PpMm只能执行简单的六种命令A,B,C,D,E,F:只有 ...
- C语言--关键字、标识(zhi)符、注释
一.关键字 1. 关键字 是C语言中提供的有特殊含义的符号,同时也叫做保留字,在C语言中关键字一共有32个,它们分别被赋予了特殊的含义.如:main.int.struct等等. 2. 关键字的特征 1 ...
- CodeForces 187A Permutations
反向思维,先求数组中不用处理的元素个数,再用n减去这个数,得到结果. #include <iostream> #include <cstring> #define maxn 2 ...