开始包含Path属性所定义的字符串,浏览器就认为通过检查。如果Path属性的
值为“/”,则Web服务器上所有的WWW资源均可读取该Cookie。同样
该项设置是可选的,如果缺省时,则Path的属性值为Web服务器传给浏览器的资
源的路径名。
可以看出我们借助对Domain和Path两个变量的设置,即可有效地控制
Cookie文件被访问的范围。
Secure:在Cookie中标记该变量,表明只有当浏览器和Web Server之间的
通信协议为加密认证协议时,浏览器才向服务器提交相应的
Cookie。当前这种协议只有一种,即为HTTPS。
以上的cookie内容中,真正发送给服务器的内容,只有NAME和VALUE对,其他东西
都是给客户端的浏览器用来管理cookie的,比如是否存放在硬盘上?存放多久?这
浏览器在访问哪个网站的时候要发这个cookie.
这几个类型的转换方法:
cookieContainer.GetCookies()获得cookieCollection,而cookieCollection直
接加索引号获得某一个具体的cookie,
cookieContainer.add()可以添加cookie或者cookieCollection,甚至直接用
http的头中的cookie信息就可以直接往cookieContainer中添加cookie,用
cookieContainer.SetCookies(Uri, string)来实现,其中的string就是cookie的字符串内容,这个字符串可以通过response.Headers.Get("Set-Cookie")获得,这里注意一点,SetCookies()函数中的Uri,不能和cookie字符串中的域名Domain完全相同,比如Uri=new Uri("http://www.easck.com/p>
Domain=.google.com,这个时候cookieContainer.SetCookies()函数将会报错,
提示域名不正确,解决方法是,uri = new Uri("http://www.easck.com/p>
反正改为其他的类似路径都可以,为什么不能相同,谁知道呢,问微软去.就这个
地方的问题,害我耗了几个小时.
CookieContainer.GetCookieHeader()函数可以读出cookieContainer中所有指
定网站的cookie,以字符串方式显示.
自己想要输入字符串单独构造cookie,也很简单,Cookie的构造函数就搞定.
cookie操作实例
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public class Cookie
{
/// <summary>
/// Cookies赋值
/// </summary>
/// <param name="strName">主键</param>
/// <param name="strValue">键值</param>
/// <param name="strDay">有效天数</param>
/// <returns></returns>
public bool setCookie(string strName, string strValue, int strDay)
{
try
{
HttpCookie Cookie = new HttpCookie(strName);
//Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com
Cookie.Expires = DateTime.Now.AddDays(strDay);
Cookie.Value = strValue;
System.Web.HttpContext.Current.Response.Cookies.Add(Cookie);
return true;
}
catch
{
return false;
}
}
/// <summary>
/// 读取Cookies
/// </summary>
/// <param name="strName">主键</param>
/// <returns></returns>
public string getCookie(string strName)
{
HttpCookie Cookie = System.Web.HttpContext.Current.Request.Cookies[strName];
if (Cookie != null)
{
return Cookie.Value.ToString();
}
else
{
return null;
}
}
/// <summary>
/// 删除Cookies
/// </summary>
/// <param name="strName">主键</param>
/// <returns></returns>
public bool delCookie(string strName)
{
try
{
HttpCookie Cookie = new HttpCookie(strName);
//Cookie.Domain = ".xxx.com";//当要跨域名访问的时候,给cookie指定域名即可,格式为.xxx.com
Cookie.Expires = DateTime.Now.AddDays(-1);
System.Web.HttpContext.Current.Response.Cookies.Add(Cookie);
return true;
}
catch
{
return false;
}
}
}










