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

类别:编程语言 点击:0 评论:0 推荐:
跨域名的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 的时候,就都只需到这个中转的域名下的程序来取就可以了。         [email protected]  

本文地址:http://com.8s8s.com/it/it28972.htm