CSDN博客

img liyujie2000

跨域名的Cookie实现---简单另类的实现方法

发表于2004/3/11 10:03:00  2236人阅读

跨域名的Cookie实现---简单另类的实现方法
 
序言
 
前因:最近又是看到不少同仁在论坛上发贴询问怎样可以实现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)
*
**/
$url     = "";
$domain1 = "www.domain1.com";  //根据自己调试环境赋值。
$domain2 = "www.domain2.com";
 
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{
    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);
    }
}
?>
 
 
以上代码已经测试通过。
 
 
测试前提:
在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
 
0 0

相关博文

我的热门文章

img
取 消
img