总结C#网络编程中对于Cookie的设定要点
花了2天时间,彻底搞清C#中cookie的内容,搞清以下内容将让你对所有网站的cookie都尽在掌握之中. cookieCollection是一个针对一个域所有的cookie的集合 cookieContainer可以包含多个cookieCollection,这个容器可以定义大小,决定 最多装多少个cookie,如果装满了还要再装,它会自动剔除原来过期的cookie. 再说到一个cookie的结构: 变量,也有用户自己创建的变量,属性中变量是用“变量=值”形式来保存。 Set-Cookie: NAME=VALUE;Expires=DATE;Path=PATH; Domain=DOMAIN_NAME;SECURE NAME=VALUE: 这是每一个Cookie均必须有的部分。NAME是该Cookie的名称,VALUE是该 Cookie的值。在字符串“NAME=VALUE”中,不含分号、逗号和空格等 期。该属性值DATE必须以特定的格式来书写:星期几, 式来书写,系统将无法识别。该变量可省,如果缺省时, 文件将随着浏览器的关闭而自动消失。 Internet域中的Web服务器可读取浏览器所存取的Cookie,即只有来自这 置Cookie的属性值为该Web服务器的域名。 设置的Cookie。一般如果用户输入的URL中的路径部分从第一个字符 值为“/”,则Web服务器上所有的WWW资源均可读取该Cookie。同样 源的路径名。 Cookie文件被访问的范围。 通信协议为加密认证协议时,浏览器才向服务器提交相应的 都是给客户端的浏览器用来管理cookie的,比如是否存放在硬盘上?存放多久?这 浏览器在访问哪个网站的时候要发这个cookie. 这几个类型的转换方法: 接加索引号获得某一个具体的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://.google.com"),而cookie中的 Domain=.google.com,这个时候cookieContainer.SetCookies()函数将会报错, 提示域名不正确,解决方法是,uri = new Uri("http://www.google.com")即可, 反正改为其他的类似路径都可以,为什么不能相同,谁知道呢,问微软去.就这个 地方的问题,害我耗了几个小时. CookieContainer.GetCookieHeader()函数可以读出cookieContainer中所有指 定网站的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";//当要跨域名访问的时候,格式为.xxx.com Cookie.Expires = DateTime.Now.AddDays(-1); System.Web.HttpContext.Current.Response.Cookies.Add(Cookie); return true; } catch { return false; } } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |