二级域名共享cookies

本文介绍了一种在不同子域名间共享Cookie的方法,并详细说明了在ASP环境下如何正确地设置和管理Cookie,包括注意事项和常见问题解决。

之前没哪次实践过,只是听一堆人说不可以或者不成功,今天测试了下,成功实现。
OS:win2003
Browse:IE6,Mozilla1.5,Netscape8.0,Friefox1.0,Opera8.51

步骤:
1、在iis新建站点3个
www.goalercn.com(和goalercn.com),img.goalercn.com,blog.goalercn.com
2、在www.goalercn.com下建立文件testcookies.asp,代码如下:

<%
Response.Cookies("Type") = "Test Cookies"
Response.Cookies("Type").Expires = date()+30
Response.Cookies("Type").Domain = ".goalercn.com"
Response.Cookies("Type").Secure = False
Response.Write Request.Cookies("Type")
%>


3、在ad.goalercn.com下建立文件testcookies.asp,代码如下:

<%Response.Write Request.Cookies("Type")%>


4、在blog.goalercn.com下建立文件testcookies.asp,代码同上
5、因为是本机测试,修改hosts文件,把4个域名都指向到127.0.0.1,也就是添加如下内容:
    127.0.0.1     ad.goalercn.com
    127.0.0.1     blog.goalercn.com
    127.0.0.1     www.goalercn.com
    127.0.0.1     goalercn.com
6、关闭所有浏览器,开ie,打开http://www.goalercn.com/demo/testcookies.asp,显示出文本内容:Test Cookies
7、新建窗口,打开http://ad.goalercn.com/temp/testcookies.asp,显示出文本内容:Test Cookies
8、新建窗口,打开http://blog.goalercn.com/temp/testcookies.asp,同样显示出如上文本内容
9、换其他4个浏览器,都成功。

注意点:
1、Response.Cookies("Type").Secure = False,Secure属性一定要是false,或者直接不执行这行,如果Secure = True,则ad和blog的2级域名是取值不了。
2、Response.Cookies("Type").Domain = ".goalercn.com",domain的值,我设置为"goalercn.com",也就是没有前面的点,在IE下成功
其他4个浏览器没测试。
3、path我猜是不应该设置的。
4、在局域网内其他机器上,修改host指向到我机器的IP,取值成功。
5、在局域网另外一台机器上架设ad.goalercn.com,把testcookies.asp文件copy过去,同时修改host到当前机器,取值成功
 

 

 

Cookie跨域操作解决方案Cookie跨域操作

看来是个简单的问题,因为只要指定Domain属性为指定网站的根域名就可以了.

但是笔者在实际使用过程中却遇到了一些问题,的确值得注意.

环境介绍

cookie在www主域名下创建,并写入Domain属性,如:(为方便调试以下代码皆为asp代码)

Code:

Write.asp

<%
Response.Cookies(CookieName)("UserName") = "SunBird"
Response.Cookies(CookieName)("Password") = "xyz1234"
Response.Cookies(CookieName).Domain = "xxxx.com"
%>
上面文件放在www主域名下,同时在同目录下放置一个读取cookie的Read.asp

Code:

Read.asp

<%
Response.Write Request.Cookies(CookieName)("UserName")
Response.Write Request.Cookies(CookieName)("Password")
%>
再放一个Read.asp文件到另外一个子域名站点里,代码同上。

最后我们再做一个清除cookie的Clear.asp放在主域名下

Code:

Clear.asp

<%
Response.Cookies(CookieName)("UserName") = ""
Response.Cookies(CookieName)("Password") = ""
Response.Cookies(CookieName).Domain = "xxxx.com"
%>
现在可以通过下面的执行顺序来测试,Write.asp-->主域名的Read.asp-->子域名的Read.asp 所有Read.asp页面都可以读取到Write.asp创建的cookie的值
然后再运行Clear.asp进行清除,一切都Ok,看上去没有什么问题。

但是把这种方法运用到实际的站点时却出现问题了。

问题描述:
第一次登录一切ok,所有子域名都可以访问到主域名存储的cookie,但是,一旦退出之后,子域名的cookie被清除了,但是主域名的cookie仍然保留着,强行清除主域名的cookie之后,无论怎样登录主域名下都无法保存cookie了,除非关掉浏览器重新打开。


经过多次尝试之后,无意中发现问题所在,以下是测试经过。

创建一个Write2.asp的页面放在主域名下

<%
Response.Cookies(CookieName)("TEST_COOKIE") = "TEST_COOKIE"
%>
第一步:关闭浏览器后,按以下顺序执行,Write.asp-->主域名的Read.asp-->子域名的Read.asp 到这里所有Read.asp读取正常。

第二步:Clear.asp-->主域名的Read.asp-->子域名的Read.asp 到这里清除操作是成功的。

第三步:Write.asp--> Write2.asp --> 主域名Read.asp --> 子域名Read.asp 到这里两个Read.asp都可以读取到cookie的值。

第四步:重新执行第二步,发现主域名Read.asp仍然输出了值,而子域名下的Read.asp的值已经被清空了。


根据以上测试总结以下几点再跨域使用cookie时需要注意的地方

1、当你有一个Cookie组(或叫Cookie字典)使用Domain属性指定域名之后,当你在对该组的成员进行修改或新增的时候,一定要在操作之后加上Resonse.Cookies(CookieName).Domain属性。
2、如果没有必要,请不要修改已设置Domain的Cookie组,直接使用Response.Cookies("CookieText") = CookieValue 来创建一个新的Cookie。

===========================

删除cookie:

1、
设为空值
HttpCookie cookieUserID=new HttpCookie("UserID","");

2、
直接清除
this.Response.Cookies.Clear();

3/
<%
For Each cookie in Request.Cookies
Response.Cookies(cookie)=""
Next%>

### 如何在二级域名中设置Cookie 为了使不同子域之间共享 Cookie,在创建 Cookie 时需指定 `Domain` 属性。该属性定义了哪些主机名可以访问此 Cookie。对于希望多个子域间共享的情况,应该把 Domain 设置成主域名前加上点号的形式。 当服务器响应 HTTP 请求并打算向客户端发送一个新的 cookie 或更新现有 cookie 的时候,会通过 Set-Cookie 响应头来完成操作[^1]。具体来说: - 对于想要让 a.example.com 和 b.example.com 这两个子域能够互相读取对方所设下的 cookie,则应当将 domain 参数设定为 .example.com。 ```python import http.cookies def set_cookie(response, key, value, max_age=3600): """ Sets a cookie with the given parameters. :param response: The HTTP response object to attach the cookie header to. :type response: HttpResponse or similar :param str key: Name of the cookie. :param str value: Value stored in the cookie. :param int max_age: Maximum age before the cookie expires (in seconds). """ cookie = http.cookies.SimpleCookie() cookie[key] = value cookie[key]['domain'] = '.example.com' # Note leading dot for cross-subdomain support cookie[key]['max-age'] = max_age cookie[key]['path'] = '/' response.headers.add('Set-Cookie', cookie.output(header='')) ``` 值得注意的是,如果尝试在一个已经存在的顶级域名上设置新的带有相同名称但是不同的路径或者其它参数的 cookie ,那么新旧两者将会共存而不是覆盖前者;因此建议确保每次修改都彻底删除之前的版本再重新建立[^3]。 另外需要注意浏览器的安全策略可能会阻止某些情况下跨站脚本攻击风险较高的行为,比如从 HTTPS 页面往 HTTP 下发 cookie 等情况,所以在实际开发过程中还需要考虑这些因素的影响[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值