跨域名的Cookie实现---简单另类的实现方法
跨域名的Cookie实现---简单另类的实现方法
序言:
前因:最近又是看到不少同仁在论坛上发贴询问怎样可以实现Cookie跨域名访问。
一个老调重谈的问题,一次合理的要求与技术限制的冲撞, 想毕也困扰了不少人,所以我把自己做过的一个简单的另类实现方法与大家分享一下。
大概在去年的某个时候,老板下达一个要求,要我做一个 ReSearch ,目标是实现跨域名Cookie。
老板如此信任我,面对这样的要求,哪能够随意一口否决敷衍过去,没有办法,不服输,不轻易放弃的我本着程序员一贯的优良传统,本着 “有条件要上,没有条件创造条件也要上”的原则,硬着头皮开始了。
首先想到的 Google,输入关键字"Cookie 跨域名"
居然得到不少文章的列表,结果一看,基本上全是转载的同一篇文章,
// 实现跨域名Cookie
// 作者:Christopher Kings-Lynne 翻译:limodou
// Cookie真是一个伟大的发明.........
一口气把整个文章读了一遍,原来关键部分是用的是 Apache 的 Httpd.conf 的 URL 重写 RewriteRule
因为根据我们公司的现状和限制,没有权限写 httpd.conf ,也不可能重编译 Apache。
所以只能独自一个人继续往下走,没有办法看来只有背水一战了。
抛开所有环境因素,经过一番构思过程,然后通过代码,调试,成功实现。
下面与大家分享。
正文:
首先讲一下流程
一用户先访问 A 网站,A网站的setCookie程序在该客户端设定了几个 Cookie 变量。
该用户再访问 B 网站,直接访问B网站的getCookie程序,这个时候getCookie 程序读取不到该客户端的Cookie变量,此时B网站的getCookie 再跳转到A网站的getCookie去读取该客户端的同名Cookie 变量(当然这些变量都是原来就在第一步已经在该客户端设定好的。),A网站读取到数据就通过地址转参返给 B 网站的程序。
以下用代码均用 PHP 作为程序语言讲解。
首先我们写一个简单 SetCookie 的程序,
cookieCrossSite_setValue.php
<?php
/**
* Program Name: cookieCrossSite_setValue.php
* Author: Eric Li (CN-SZ ISD)
* Date created:
* Description:
* Revision History(Verdion,Modifid By,Date of Change,Comments of Change)
*
**/
setcookie("cookie_user_id", "800800800", time()+10800);
setcookie("cookie_user_name", "Ericli", time()+10800);
setcookie("cookie_user_type", "VIP", time()+10800);
?>
上面这个 SetCookie 程序没有什么好说的,我们接着看下面这个文件。
cookieCrossSite_getValue.php
<?php
/**
* Program Name: cookieCrossSite_getValue.php
* Author: Eric Li (CN-SZ ISD)
* Date created:
* Description:
* Revision History(Verdion,Modifid By,Date of Change,Comments of Change)
*
**/
/**
* Program Name: cookieCrossSite_getValue.php
* Author: Eric Li (CN-SZ ISD)
* Date created:
* Description:
* Revision History(Verdion,Modifid By,Date of Change,Comments of Change)
*
**/
if ($comeFrom == $domain1){
// display the variable.
echo "cookie_user_id = ".$cookie_user_id."<br>";
echo "cookie_user_name = ".$cookie_user_name."<br>";
echo "cookie_user_type = ".$cookie_user_type."<br>";
}else{
// display the variable.
echo "cookie_user_id = ".$cookie_user_id."<br>";
echo "cookie_user_name = ".$cookie_user_name."<br>";
echo "cookie_user_type = ".$cookie_user_type."<br>";
}else{
if (count($HTTP_COOKIE_VARS)==0){
header("Location:http://".$domain1."/cookieCrossSite_getValue.php?comeFrom=".$domain2);
}else{
while (list($name, $value) = each($HTTP_COOKIE_VARS)){
if ($value==""){
}else{
if ($comeFrom != "$domain2"){
// display all cookie variables.
echo "Name = ".$name." | Value = ".$value."<br>";
}
// generate a url string.
// 这里可以适当的加上 urlencode 进行编码。
$url .= $name."=".$value."&";
}
}
}
if ($comeFrom == $domain2){
header("Location:http://".$domain2."/cookieCrossSite_getValue.php?comeFrom=".$domain1."&".$url);
}
}
?>
header("Location:http://".$domain1."/cookieCrossSite_getValue.php?comeFrom=".$domain2);
}else{
while (list($name, $value) = each($HTTP_COOKIE_VARS)){
if ($value==""){
}else{
if ($comeFrom != "$domain2"){
// display all cookie variables.
echo "Name = ".$name." | Value = ".$value."<br>";
}
// generate a url string.
// 这里可以适当的加上 urlencode 进行编码。
$url .= $name."=".$value."&";
}
}
}
if ($comeFrom == $domain2){
header("Location:http://".$domain2."/cookieCrossSite_getValue.php?comeFrom=".$domain1."&".$url);
}
}
?>
以上代码已经测试通过。
测试前提:
在A 域名根目录下放两个文件
cookieCrossSite_setValue.php
cookieCrossSite_getValue.php
在B域名根目录下放一个文件
cookieCrossSite_getValue.php
测试步骤:
先访问A 域名的 cookieCrossSite_setValue.php
然后访问 B域名的 cookieCrossSite_getValue.php
补充:
当然上面的代码只是给出一个另外实现的思路,为了更清楚了解过程,所以在URL传递参数的时候,没有对数据进行编码。
如果想要实现多个域名之间的cookie跨越,那么最好是,
用其中一个域名做中转,当 setCookie 的时候,其他几个网站的程序都跳到该中转服务器来做一次 setCookie,然后所有getCookie 的时候,就都只需到这个中转的域名下的程序来取就可以了。
liyujie2000@sohu.com
中国海量技术资料网站超级搜索
本站声明
- 如果您发现链接错误,请通知我们,不胜感激。
- 如果您认为本站文章侵犯您的版权,请通知我们,我们将立即删除。
- 本站提供的文章收集连接于其他网站,版权归作者所有。
- 本站的文章仅供学习和研究之用,严禁用于商业用途。
最新统计
- 文章中心总数:51611篇
- 今日更新文章:0篇
- 本周更新文章:0篇
- 备用更新文章:10篇

