概述 Cookie用来保存客户浏览器请求服务器页面的请求信息。 我们可以存放非敏感的用户信息,保存时间可以根据需要设置。如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览
概述
Cookie用来保存客户浏览器请求服务器页面的请求信息。
我们可以存放非敏感的用户信息,保存时间可以根据需要设置。如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止,Cookie对象的Expires属性设置为MinValue表示永不过期。
Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据。
由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端。
一、创建Cookie:发送到客户端浏览器
Domain和Path相同的所有Cookie在客户端存在于一个文件中。
//通用设置 Response.Cookies["userName"].Value = "Park"; Response.Cookies["userName"].Expires = DateTime.Now.AddDays(1);//不设Expires默认关闭浏览器就过期 Response.Cookies["userName"].Domain = "park.aa.com";//Domain默认为域名部分,以表示aa.com下的所有子域名。 Response.Cookies["userName"].Path = "App1";//Path默认为根目录"/",表示根目录下的所有页面和子目录 //单值Cookie HttpCookie Cookie = new HttpCookie("userName"); cookie.Value = "Park"; cookie.Expires = DateTime.Now.AddDays(1); Response.Cookies.Add(cookie); //多值Cookie HttpCookie cookies = new HttpCookie("userName"); cookies["name"] = "Park"; cookies["sex"] = "1"; cookies.Expires = DateTime.Now.AddMinutes(20); Response.Cookies.Add(cookies); //Response.SetCookies(cookies) //Response.AppendCookis(cookies);
二、读取Cookie:
Domain、Path和Expires是无法读取的
if (Request.Cookies["userName"] != null) { //读取多值Cookie Response.Write(Request.Cookies["userName"].Value) //可以Server.HtmlEncode()编码 //读取多值Cookie Response.Write("Cookie中键值为userid的值:" + Request.Cookies["userName"]["sex"]); }
三、修改Cookie
不能直接修改一个Cookie,是创建一个同名的Cookie,并把该Cookie发送到浏览器覆盖客户机上的旧Cookie。
HttpCookie cok = Request.Cookies["userName"];//获取客户端的Cookie对象 if (cok != null) { cok.Values["userid"] = "alter-value";//修改Cookie cok.Values.Set("newid", "newValue");//往Cookie里加入新的内容 Response.AppendCookie(cok); //或者 Response.Cookies["userName"].Value = "aa"; } Response.Cookies["Porschev"].Expires = DateTime.Now.AddMinutes(-1);
四、删除Cookie:
无法直接删除一个Cookie,可通过修改它的Expires为过去的某个时间,浏览器会删除已经过期的Cookie。
Response.Cookies["userName"].Expires = DateTime.Now.AddDays(-1); //或者 HttpCookie cok = Request.Cookies["userName"]; if (cok != null) { if (!CheckBox1.Checked) { cok.Values.Remove("userid");//移除键值为userid的值 } else { TimeSpan ts = new TimeSpan(0, 0, 0, 0); cok.Expires = DateTime.Now.Add(ts);//删除整个Cookie,只要把过期时间设置为现在 } Response.AppendCookie(cok); }
到此这篇关于ASP.NET操作Cookie的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持自由互联。