asp.net Cookie跨域、虚拟目录等设置方法
程序员文章站
2024-03-31 19:46:40
cookie有三个属性需要注意一下: . domain 域 . path 路径 . expires 过期时间 跨域操作需要设置域属性: response.cookies("...
cookie有三个属性需要注意一下:
. domain 域
. path 路径
. expires 过期时间
跨域操作需要设置域属性:
response.cookies("mycookie").domain = "jb51.net"; (这里指的是泛域名)
这样在其它二级域名下就都可以访问到了, asp 和 asp.net 测试通过
虚拟目录下访问:
我在asp端做了下测试,.net的没试, 如果不指定path属性, 不同虚拟目录下cookie无法共享
将response.cookies("mycookie").path = "/" 就可以了
总的写法:
response.cookies("mycookie").domain = "jb51.net";
response.cookies("mycookie").path = "/"
response.cookies("mycookie").expires = now + 365;
response.cookies("mycookie")("test") = "test";
.net 清除cookie
httpcookie cookie = system.web.httpcontext.current.request.cookies[cookiename];
if (cookie != null)
{
cookie.values.clear();
setusercookieexpiretime(cookiename, -1);
cookie.domain = _domain;
system.web.httpcontext.current.response.cookies.set(cookie);
}
public static void setusercookieexpiretime(string key, int days)
{
system.web.httpcontext.current.response.cookies[key].domain = _domain;
system.web.httpcontext.current.response.cookies[key].path = _cookiepath;
system.web.httpcontext.current.response.cookies[key].expires = datetime.now.adddays(days);
}
.net 添加/更新cookie
public static void addusercookies(string key,string value, string cookiename, string domain)
{
httpcookie cookie = system.web.httpcontext.current.request.cookies[cookiename];
if (cookie == null)
{
cookie = new httpcookie(cookiename);
cookie.domain = domain;
cookie.path = _cookiepath;
cookie.values.add(key, value);
httpcontext.current.response.appendcookie(cookie);
}
else
{
if (system.web.httpcontext.current.request.cookies[cookiename].values[key] != null)
{
cookie.values.set(key, value);
}
else
{
cookie.domain = domain;
cookie.path = _cookiepath;
cookie.values.add(key, value);
httpcontext.current.response.appendcookie(cookie);
}
}
}
身份验证cookie域,什么意思?
默认情况下,cookie 与特定的域相关联。例如,如果您的站点是 www.jb51.net,那么当用户向该站点请求页面时,您编写的 cookie 就被发送到服务器。(有特定路径值的 cookie 除外。) 如果您的站点有子域(例如 jb51.net、s.jb51.net 和 tools.jb51.net),就可以把 cookie 同特定的子域相关联。为此,需要设置 cookie 的 domain 属性,如下所示:
response.cookies("domain").value = datetime.now.tostring
response.cookies("domain").expires = datetime.now.adddays(1)
response.cookies("domain").domain = "s.jb51.net"
如果按照这种方式设置域,则 cookie 只能用于指定子域中的页面。
您也可以利用 domain 属性来创建可在多个子域*享的 cookie。例如,对域进行如下设置:
response.cookies("domain").value = datetime.now.tostring
response.cookies("domain").expires = datetime.now.adddays(1)
response.cookies("domain").domain = "jb51.net"
这样,该 cookie 就可用于主域、s.jb51.net 和 tools.jb51.net。
. domain 域
. path 路径
. expires 过期时间
跨域操作需要设置域属性:
response.cookies("mycookie").domain = "jb51.net"; (这里指的是泛域名)
这样在其它二级域名下就都可以访问到了, asp 和 asp.net 测试通过
虚拟目录下访问:
我在asp端做了下测试,.net的没试, 如果不指定path属性, 不同虚拟目录下cookie无法共享
将response.cookies("mycookie").path = "/" 就可以了
总的写法:
复制代码 代码如下:
response.cookies("mycookie").domain = "jb51.net";
response.cookies("mycookie").path = "/"
response.cookies("mycookie").expires = now + 365;
response.cookies("mycookie")("test") = "test";
.net 清除cookie
复制代码 代码如下:
httpcookie cookie = system.web.httpcontext.current.request.cookies[cookiename];
if (cookie != null)
{
cookie.values.clear();
setusercookieexpiretime(cookiename, -1);
cookie.domain = _domain;
system.web.httpcontext.current.response.cookies.set(cookie);
}
public static void setusercookieexpiretime(string key, int days)
{
system.web.httpcontext.current.response.cookies[key].domain = _domain;
system.web.httpcontext.current.response.cookies[key].path = _cookiepath;
system.web.httpcontext.current.response.cookies[key].expires = datetime.now.adddays(days);
}
.net 添加/更新cookie
复制代码 代码如下:
public static void addusercookies(string key,string value, string cookiename, string domain)
{
httpcookie cookie = system.web.httpcontext.current.request.cookies[cookiename];
if (cookie == null)
{
cookie = new httpcookie(cookiename);
cookie.domain = domain;
cookie.path = _cookiepath;
cookie.values.add(key, value);
httpcontext.current.response.appendcookie(cookie);
}
else
{
if (system.web.httpcontext.current.request.cookies[cookiename].values[key] != null)
{
cookie.values.set(key, value);
}
else
{
cookie.domain = domain;
cookie.path = _cookiepath;
cookie.values.add(key, value);
httpcontext.current.response.appendcookie(cookie);
}
}
}
身份验证cookie域,什么意思?
默认情况下,cookie 与特定的域相关联。例如,如果您的站点是 www.jb51.net,那么当用户向该站点请求页面时,您编写的 cookie 就被发送到服务器。(有特定路径值的 cookie 除外。) 如果您的站点有子域(例如 jb51.net、s.jb51.net 和 tools.jb51.net),就可以把 cookie 同特定的子域相关联。为此,需要设置 cookie 的 domain 属性,如下所示:
复制代码 代码如下:
response.cookies("domain").value = datetime.now.tostring
response.cookies("domain").expires = datetime.now.adddays(1)
response.cookies("domain").domain = "s.jb51.net"
如果按照这种方式设置域,则 cookie 只能用于指定子域中的页面。
您也可以利用 domain 属性来创建可在多个子域*享的 cookie。例如,对域进行如下设置:
复制代码 代码如下:
response.cookies("domain").value = datetime.now.tostring
response.cookies("domain").expires = datetime.now.adddays(1)
response.cookies("domain").domain = "jb51.net"
这样,该 cookie 就可用于主域、s.jb51.net 和 tools.jb51.net。