总结C#网络编程中对于Cookie的设定要点

2019-12-30 12:10:08于海丽

开始包含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;
    }
  }
}