随笔 - 1330  文章 - 1  评论 - 376  0

Cookie有三个属性需要注意一下:
    1. Domain  域
    2. Path       路径
    3. Expires  过期时间

跨域操作需要设置域属性:
Response.Cookies("MyCookie").Domain = "cnblogs.com"; (这里指的是泛域名)
这样在其它二级域名下就都可以访问到了, ASP 和 ASP.NET 测试通过

虚拟目录下访问:
我在ASP端做了下测试,.NET的没试,  如果不指定Path属性, 不同虚拟目录下Cookie无法共享
将Response.Cookies("MyCookie").Path = "/" 就可以了

总的写法:
Response.Cookies("MyCookie").Domain = "cnblogs.com";
Response.Cookies("MyCookie").Path = "/"
Response.Cookies("MyCookie").Expires = Now + 365;
Response.Cookies("MyCookie")("Test") = "test";

.NET 清除Cookie

 1 HttpCookie cookie = System.Web.HttpContext.Current.Request.Cookies[cookiename];
 2 if (cookie != null)
 3 {
 4                 cookie.Values.Clear();
 5                 SetUserCookieExpireTime(cookiename, -1);
 6                 cookie.Domain = _domain;
 7                 System.Web.HttpContext.Current.Response.Cookies.Set(cookie);
 8  }
 9 public static void SetUserCookieExpireTime(string key, int days)
10 {
11             System.Web.HttpContext.Current.Response.Cookies[key].Domain = _domain;
12             System.Web.HttpContext.Current.Response.Cookies[key].Path = _cookiepath;
13             System.Web.HttpContext.Current.Response.Cookies[key].Expires = DateTime.Now.AddDays(days);
14 }
15 

.NET 添加/更新Cookie

 1 public static void AddUserCookies(string key,string value, string cookiename, string domain)
 2 {
 3             HttpCookie cookie = System.Web.HttpContext.Current.Request.Cookies[cookiename];
 4             if (cookie == null)
 5             {
 6                 cookie = new HttpCookie(cookiename);
 7                 cookie.Domain = domain;
 8                 cookie.Path = _cookiepath;
 9 
10                 cookie.Values.Add(key, value);
11                 HttpContext.Current.Response.AppendCookie(cookie);
12             }
13             else
14             {
15                 if (System.Web.HttpContext.Current.Request.Cookies[cookiename].Values[key] != null)
16                 {
17                     cookie.Values.Set(key, value);
18                 }
19                 else
20                 {
21                     cookie.Domain = domain;
22                     cookie.Path = _cookiepath;
23 
24                     cookie.Values.Add(key, value);
25                     HttpContext.Current.Response.AppendCookie(cookie);
26                 }
27             }
28 }
29 

===============================================================================
身份验证Cookie域,什么意思?

默认情况下,Cookie  与特定的域相关联。例如,如果您的站点是  www.contoso.com,那么当用户向该站点请求页面时,您编写的  Cookie  就被发送到服务器。(有特定路径值的  Cookie  除外。)  如果您的站点有子域(例如  contoso.com、sales.contoso.com  和  support.contoso.com),就可以把  Cookie  同特定的子域相关联。为此,需要设置  Cookie  的  Domain  属性,如下所示: 
   
  Response.Cookies("domain").Value  =  DateTime.Now.ToString 
  Response.Cookies("domain").Expires  =  DateTime.Now.AddDays(1) 
  Response.Cookies("domain").Domain  =  "support.contoso.com" 
   
  如果按照这种方式设置域,则  Cookie  只能用于指定子域中的页面。 
   
  您也可以利用  Domain  属性来创建可在多个子域中共享的  Cookie。例如,对域进行如下设置: 
   
  Response.Cookies("domain").Value  =  DateTime.Now.ToString 
  Response.Cookies("domain").Expires  =  DateTime.Now.AddDays(1) 
  Response.Cookies("domain").Domain  =  "contoso.com" 
   
  这样,该  Cookie  就可用于主域、sales.contoso.com  和  support.contoso.com。


posted on 2009-03-06 11:13 钱途无梁 阅读(...) 评论(...) 编辑 收藏