Cookie跨域、虚拟目录, 实现通行证登录

  1. 总的写法:
  2. Response.Cookies("MyCookie").Domain = "cnblogs.com";
  3. Response.Cookies("MyCookie").Path = "/"
  4. Response.Cookies("MyCookie").Expires = Now + 365;
  5. Response.Cookies("MyCookie")("Test") = "test";
  6. .NET 清除Cookie
  7. HttpCookie cookie = System.Web.HttpContext.Current.Request.Cookies[cookiename];
  8. if (cookie != null)
  9. {
  10.                 cookie.Values.Clear();
  11.                 SetUserCookieExpireTime(cookiename, -1);
  12.                 cookie.Domain = _domain;
  13.                 System.Web.HttpContext.Current.Response.Cookies.Set(cookie);
  14.  }
  15. public static void SetUserCookieExpireTime(string key, int days)
  16. {
  17.             System.Web.HttpContext.Current.Response.Cookies[key].Domain = _domain;
  18.             System.Web.HttpContext.Current.Response.Cookies[key].Path = _cookiepath;
  19.             System.Web.HttpContext.Current.Response.Cookies[key].Expires = DateTime.Now.AddDays(days);
  20. }
  21. .NET 添加/更新Cookie
  22. public static void AddUserCookies(string key,string value, string cookiename, string domain)
  23. {
  24.             HttpCookie cookie = System.Web.HttpContext.Current.Request.Cookies[cookiename];
  25.             if (cookie == null)
  26.             {
  27.                 cookie = new HttpCookie(cookiename);
  28.                 cookie.Domain = domain;
  29.                 cookie.Path = _cookiepath;
  30.                 cookie.Values.Add(key, value);
  31.                 HttpContext.Current.Response.AppendCookie(cookie);
  32.             }
  33.             else
  34.             {
  35.                 if (System.Web.HttpContext.Current.Request.Cookies[cookiename].Values[key] != null)
  36.                 {
  37.                     cookie.Values.Set(key, value);
  38.                 }
  39.                 else
  40.                 {
  41.                     cookie.Domain = domain;
  42.                     cookie.Path = _cookiepath;
  43.                     cookie.Values.Add(key, value);
  44.                     HttpContext.Current.Response.AppendCookie(cookie);
  45.                 }
  46.             }
  47. }
Cookie有三个属性需要注意一下:
1. Domain  域
2. Path       路径
3. Expires  过期时间

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

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值