多个域上的域级会话 cookie

发布于 2025-01-06 00:13:43 字数 590 浏览 1 评论 0原文

如果您希望 ColdFusion 将会话 cookie 创建为域级别 cookie,例如 .bar.com 而不是 foo.bar.com,那么您可以在 jrun-web.xml 中进行配置:-

<session-config>    
   <cookie-config>
          <active>true</active>
          <cookie-domain>.bar.com</cookie-domain>
   </cookie-config>
  <persistence-config>
    <active>false</active>
  </persistence-config>
</session-config>

但是,这是一个实例范围的设置,因此如果如果您希望在该实例上运行两个应用程序,或者实际上运行一个具有或多个不同顶级域的应用程序,那么其中一个应用程序的会话将无法正常工作。

有没有一种方法可以将多个域添加到 jrun-web.xml 并让它选择相关的域?

谢谢。

If you want ColdFusion to create your session cookie as a domain level cookie e.g. .bar.com rather than foo.bar.com then you can configure that in the jrun-web.xml:-

<session-config>    
   <cookie-config>
          <active>true</active>
          <cookie-domain>.bar.com</cookie-domain>
   </cookie-config>
  <persistence-config>
    <active>false</active>
  </persistence-config>
</session-config>

However, this is an instance wide setting so if you want to run two applications on that instance or indeed one application with or more different top-level domains then one of them will have sessions that do not work.

Is there a way to add multiple domains to the jrun-web.xml and have it pick the relevant one?

Thanks.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

↙温凉少女 2025-01-13 00:13:43

我设法找到jrun-web.xml的DTD< /a> (顶部的链接 @ 指向已失效的 Macromedia URL)。

这指定 XML 中只能有一个 节点。我还测试了域名列表,例如:

<cookie-domain>.domainA.com,.domainB.com</cookie-domain>

这也不起作用。

不是一个绝对的答案,但我怀疑这可能是不可能的(!),并且通过 jrun-web.xml 肯定不可能(我想这至少回答了您的问题之一)。

I managed to find the DTD for jrun-web.xml (the link @ the top points to a defunct Macromedia URL).

This specifies that there can be only one <cookie-domain> node in the XML. I've also tested a list of domain names, eg:

<cookie-domain>.domainA.com,.domainB.com</cookie-domain>

And that doesn't work either.

Not an absolute answer, but I suspect that it's possibly not possible (!), and it's certainly not possible via jrun-web.xml (which I guess answers one of your questions at least).

宁愿没拥抱 2025-01-13 00:13:43
<cfapplication
   setdomaincookies=yes
   .....>

这会将您的 cfid 和 cftoken cookie 设置为域 cookie (*.bar.com),而不是特定于主机的值 (foo.bar.com)。

CFApplication(请参阅有关 setDomainCookies 的部分)

<cfapplication
   setdomaincookies=yes
   .....>

This will set your cfid and cftoken cookies as domain cookies (*.bar.com) rather than the host-specific values (foo.bar.com).

CFApplication (see the section on setDomainCookies)

不即不离 2025-01-13 00:13:43

我认为您可以使用 来设置域 cookie,而不是

I think you could use <CFHEADER> to set domain cookies instead of <CFCOOKIE>?

jJeQQOZ5 2025-01-13 00:13:43

我认为,如果您使用 cgi.server_name 变量命名您的应用程序,并且您的每个站点都使用相同的 application.cfc 或 application.cfm 文件,那么您的会话和 cookie 变量将针对每个单独的站点正确确定范围。例如:

<cfapplication name="#cgi.server_name#" sessionmanagement="YES" clientmanagement="YES" sessiontimeout="#CreateTimeSpan(1,0,0,0)#" applicationtimeout="#CreateTimeSpan(1,0,0,0)#"  clientstorage="COOKIE" setclientcookies="YES">

I think if you name your application with the cgi.server_name variable, and each of your sites uses the same application.cfc or application.cfm file, then your session and cookie variables will be properly scoped for each individual site. For example:

<cfapplication name="#cgi.server_name#" sessionmanagement="YES" clientmanagement="YES" sessiontimeout="#CreateTimeSpan(1,0,0,0)#" applicationtimeout="#CreateTimeSpan(1,0,0,0)#"  clientstorage="COOKIE" setclientcookies="YES">
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文