Cookie
Cookie真是一个伟大的发明,它允许web开发者保留他们的用户的登录状态。然而,当你的站点或网络有一个以上的域名时就会出现问题了。
在Cookie规范上说,一个cookie只能用于一个域名,不能够发给其它的域名。因此,如果在浏览器中对
一个域名设置了一个cookie,这个cookie对于其它的域名将无效。如果你想让你的用户从你的站点中的其中
一个进行登录,同时也可以在其它域名上进行登录,这可真是一个大难题。
我的解决方案将使用下面的一般框架:
一个预置的脚本将用来接受通过GET或COOKIE方式传递过来的sessionid号。它将比COOKIE优先选择GET
变量。所以,无论何时需要引用交叉的域名时,我们把sessionid做为一个URL参数进行发送。
修改Apache配置,用来实现重写所有的交叉域名的cookie。这样做的原因一会儿就会清楚了。
在任何时候出现一个交叉域名引用时使用变量。
第一步:创建预置脚本
将下面的代码加到预置脚本中(或出现在所有脚本之前的函数中)。
<font color="#000000">
<font color="#0000BB"></font><font color="#007700"></font><font color="#0000BB">php <br><br></font><font color="#FF8000">/* 支持交叉域名cookie... */ <br><br>// 如果GET变量已经设置了,并且它与cookie变量不同 <br>//则使用get变量(更新cookie) <br></font><font color="#007700">global </font><font color="#0000BB">$HTTP_COOKIE_VARS</font><font color="#007700">, </font><font color="#0000BB">$HTTP_GET_VARS</font><font color="#007700">; <br>if (isset(</font><font color="#0000BB">$sessionid</font><font color="#007700">) && isset(</font><font color="#0000BB">$HTTP_GET_VARS</font><font color="#007700">['</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">]) && ($HTTP_COOKIE_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">] != $HTTP_GET_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">])) { <br>SetCookie(</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">, $HTTP_GET_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">], 0, </font><font color="#007700">\'</font><font color="#0000BB">/</font><font color="#007700">\'</font><font color="#0000BB">, </font><font color="#007700">\'\'</font><font color="#0000BB">); <br>$HTTP_COOKIE_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">] = $HTTP_GET_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">]; <br>$sessionid = $HTTP_GET_VARS[</font><font color="#007700">\'</font><font color="#0000BB">sessionid</font><font color="#007700">\'</font><font color="#0000BB">]; <br>} <br><br>?></font>
</font>
一旦这个代码运行之后,一个全局的\'sessionid\'变量将可以用于脚本。它将保存着用户的cookie中的
sessionid值,或者是通过GET请求发来的sessionid值。
第二步:为所有的交叉域名引用使用变量
创建一个全局的配置文件,用于存放可以进行切换的域名的基本引用形式。例如,如果我们拥有
domain1.com和domain2.com,则如下设置:
<font color="#000000">
<font color="#0000BB"></font><font color="#007700"></font><font color="#0000BB">php <br><br>$domains</font><font color="#007700">['</font><font color="#0000BB">domain1</font><font color="#007700">\'</font><font color="#0000BB">] = "http://www.domain1.com/-$sessionid-"; <br>$domains[</font><font color="#007700">\'</font><font color="#0000BB">domain2</font><font color="#007700">\'</font><font color="#0000BB">] = "http://www.domain2.com/-$sessionid-"; <br><br>?></font>
</font>
现在,如果在代码中如下做:
<font color="#000000">
<font color="#0000BB"></font><font color="#007700"></font><font color="#0000BB">php <br><br></font><font color="#007700">echo </font><font color="#DD0000">"Click <a href="%5C%22%22</font"><font color="#007700">, </font><font color="#0000BB">$domains</font><font color="#007700">['</font><font color="#0000BB">domain2</font><font color="#007700">\'</font><font color="#0000BB">], "/contact/?email=yes\">here</font></a> to contact us."; <br><br>?></font>
</font>
你将产生如下的输出:
Click here
to contact us.
在这里sessionid已经被插入到URL中去了。
在这个地方,你可能会想"这样可能会在web服务器上打开名为横线,sessionid,横线的子目录?!?!?"。
然而,下面的步骤将提供一个必需的戏法,以便让它能够使用!
第三步:配置Apache
现在,剩下的步骤就是配置apache来重写这个URL:
http://www.domain2.com/-66543afe6543asdf6asd-/contact/
变成这样:
http://www.domain2.com/contact/?sessionid=66543afe6543asdf6asd
并且这种url:
http://www.domain2.com/-66543afe6543asdf6asd-/contact/?email=yes
变成这样:
http://www.domain2.com/contact/?email=yes&sessionid=66543afe6543asdf6asd
为了实现它,简单地配置两个虚拟服务器,作为domain1和domain2,如下操作:
DocumentRoot /usr/local/www/domain1
ServerName www.domain1.com
RewriteEngine on
RewriteRule ^/-(.*)-(.*\?.*)$ $2&sessionid=$1 [L,R,QSA]
RewriteRule ^/-(.*)-(.*)$ $2?sessionid=$1 [L,R,QSA]
DocumentRoot /usr/local/www/domain2
ServerName www.domain2.com
RewriteEngine on
RewriteRule ^/-(.*)-(.*\?.*)$ $2&sessionid=$1 [L,R,QSA]
RewriteRule ^/-(.*)-(.*)$ $2?sessionid=$1 [L,R,QSA]
这些重写的规则实现了上面两个URL重写的要求。
结论
通过使用变量结合与apache的重写功能,交叉域名cookie可以以一种简单的方式实现。想要维护这样的
系统,无论什么时候链接交叉域名,在使用域名变量之外,什么也不用作了!在域名内部的链接不需要进行
修改,因为cookie会工作正常。
如果你有兴趣看一下在生产网络中实际运作中的系统,请参观http://www.familyhealth.com.au/。在
一些交叉域名链接上移动你的鼠标,并且看一下当你点击后它们是如何被重写的。
也许,使用这个技术唯一的问题就是无法删除在用户浏览器中的全部域名下的cookie。

主机的域名和主机的ip地址两者之间的关系是:一个IP地址对应多个域名。IP地址用数字化形式来对计算机网络中的主机进行网络标识,域名用字符化形式来对计算机网络中的主机进行网络标识。在Internet中,一个域名之内能够对应一个IP地址,但是一个IP地址可以被多个域名所对应。

在TCP/IP协议套件中,域名系统是提供计算机名称到IP地址映射名称解析服务的协议之一。但是,有时它会出现故障,从而导致错误,例如请求的控制对此服务NETHELPMSG2191无效。DNS客户端和服务器协同工作,为计算机和用户提供计算机名称到IP地址映射名称解析服务。安装Windows后,客户端和服务器版本的操作系统默认启用客户端服务。一旦您在TCP/IP网络配置中指定了服务器的IP地址,DNS客户端就会查询服务器以发现域控制器并将计算机名称解析为IP地址。只有在服务

申请方法:1、通过工信部网站申请免费域名,等待审核通过后即可获得免费域名;2、通过DNSPod免费申请域名,用户可以在DNSPod上注册账号并申请免费的二级域名;3、选择一个可靠的免费域名服务提供商,通过对比和了解,选择一个可靠的提供商;4、注册账号,点击注册按钮,按照要求填写相关个人信息并创建账号;5、搜索并选择域名即可。

Discuz域名修改操作指南在使用Discuz论坛系统的过程中,有时候我们需要修改论坛的域名。可能是因为需要更换域名,或者是修复一些域名解析的问题。本文将为大家详细介绍如何在Discuz论坛系统中进行域名修改操作,并给出一些具体的代码示例。1.备份数据在进行任何操作之前,我们都要先备份数据,以防止因操作失误导致数据丢失。在Discuz中,可以使用后台的数据备

1、选择一个可用的域名:企业邮箱域名应当与企业的品牌或业务相关。2、查询域名是否已被注册:在选择企业邮箱域名后,需要查询该域名是否已经被其他企业注册。3、选择邮箱服务供应商:企业可通过搜索引擎查找不同的邮箱服务供应商,根据自己的需求选择一个供应商。4、创建账户:注册邮箱服务的过程可能略有不同,但是通常需要填写企业和管理员的基本信息,并创建一个管理员账户。

PHP域名重定向是网站开发中常用的技术之一,通过域名重定向可以实现让用户访问一个网址自动跳转到另一个网址,从而实现网站的流量导向、品牌宣传等目的。下面将以一个具体的实例来演示PHP域名重定向的实现方法,并展示效果。创建一个简单的PHP文件,命名为redirect.php,代码如下:

随着物联网技术的发展和普及,越来越多的应用场景需要使用PHP语言进行物联网开发。PHP作为一种广泛应用于Web开发的脚本语言,它的易学易用、开发速度快、可扩展性强等特点,使其成为开发物联网应用的一种优秀选择。本文将介绍在PHP中实现物联网开发的常用技术和方法。一、传输协议和数据格式物联网设备通常使用TCP/IP或UDP协议进行数据传输,而HTTP协议是一个优

如何使用Nginx实现基于域名的虚拟主机配置概述:在Web服务器中,虚拟主机是指一台物理服务器上运行多个托管域名的Web网站。通过使用虚拟主机配置,可以实现多个域名共享同一台服务器,并且每个域名都可以有独立的配置和内容。Nginx是一个开源的高性能Web服务器,也可以用作反向代理服务器和负载均衡器。本文将介绍如何使用Nginx实现基于域名的虚拟主机配置。步骤


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

メモ帳++7.3.1
使いやすく無料のコードエディター

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません
