跨域名的Cookie实现---简单另类的实现方法 选择自 liyujie2000 的 Blog
序言:
前因:最近又是看到不少同仁在论坛上发贴询问怎样可以实现Cookie跨域名访问。
一个老调重谈的问题,一次合理的要求与技术限制的冲撞, 想毕也困扰了不少人,所以我把自己做过的一个简单的另类实现方法与大家分享一下。
正文:
首先讲一下流程
一用户先访问 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 的时候,就都只需到这个中转的域名下的程序来取就可以了。