asp.net各种cookie代码和解析实例
Cookie是一段文本信息,在客户端存储Cookie是ASP.NET的会话状态将请求与会话关联的方法之一。Cookie也可以直接用于在请求之间保持数据,但数据随后将存储在客户端并随每个请求一起发送到服务器。浏览器对Cookie的大小有限制,因此,只有不超过4096字节才能保证被接受。
编写Cookie
//方式1:
Response.Cookies["username"].value="mike";
Response.Cookies["username"].Expires=DateTime.MaxValue;
//方式2:
HttpCookieacookie=newHttpCookie("last");
acookie.Value="a";
acookie..Expires=DateTime.MaxValue;
Response.Cookies.Add(acookie);
//方式1:
Response.Cookies["userinfo1"]["name"].value="mike";
Response.Cookies["userinfo1"]["last"].value="a";
Response.Cookies["userinfo1"].Expires=DateTime.MaxValue;
//方式2:
HttpCookiecookie=newHttpCookie("userinfo1");
cookie.Values["name"]="mike";
cookie.Values["last"]="a";
cookie.Expires=DateTime.MaxValue;
//cookie.Expires=System.DateTime.Now.AddDays(1);//设置过期时间 1天
Response.Cookies.Add(cookie);
读取Cookie
InternetExplorer将站点的Cookie保存在文件名格式为<user>@<domain>.txt的文件中,其中<user>是您的帐户名。
注意:在获取Cookie的值之前,应该确保该Cookie确实存在。否则,您将得到一个异常
If(Request.Cookies["userName"]!=null)
{
stringstr=Request.Cookies("userName").Value;
}
//多值Cookie的读取
If(Request.Cookies["userInfo1"]!=null)
{
stringname=Request.Cookies["userInfo1"]["name"];
stringlast=Request.Cookies["userInfo1"]["last"];
}
//读取Cookie集合
for(inti=0;i<Request.Cookies.Count;i++)
{
HttpCookiecookies=Request.Cookies;
Response.Write("name="+cookies.Mame+"<br/>");
if(cookies.HasKeys)//是否有子键
{
System.Collections.Specialized.NameValueCollectionNameColl
=aCookie.Values;
for(intj=0;j<NameColl.Count;j++)
{
Response.Write("子键名="+NameColl.AllKey[j]+"<br/>");
Response.Write("子键值="+NameColl[j]+"<br/>");
}
}
else
{
Response.Write("value="+cookies.Value+"<br/>");
}
}
运行此代码时,可看到一个名为“ASP.NET_SessionId”的Cookie,ASP.NET用这个Cookie来保存您的会话的唯一标识符。
修改Cookie
修改的方法与创建方法相同
删除Cookie
将其有效期设置为过去的某个日期。当浏览器检查Cookie的有效期时,就会删除这个已过期的Cookie。
如果有主站及二级域名站且cookie要共享的话则要加入如下设置 Cookie.ExpiresAddDays(-1)是立即过期
HttpCookiecookie=newHttpCookie("userinfo1");
cookie.Expires=DateTime.Now.AddDays(-30);
Response.Cookies.Add(cookie);
修改cookie
Response.Cookies["Info"]["user"]="2";
Response.Cookies["Info"].Expires=DateTime.Now.AddDays(1); //删除cookie下的属性
HttpCookieacookie=Request.Cookies["Info"];
acookie.Values.Remove("userid");
acookie.Expires=DateTime.Now.AddDays(1);
Response.Cookies.Add(acookie); //删除所有cookie,就是设置过期时间为现在就行了
intlimit=Request.Cookies.Count-1;
for(inti=0;i<limit;i++)
{
acookie=Request.Cookies(i)
acookie.Expires=DateTime.Now.AddDays(-1)
Response.Cookies.Add(acookie)
}
cookie.Domain=".主域名";//例如.keleyi.com
cookie.Path="/";
相关文章