CDEFGAB 1010110

挖了太多坑,一点点填回来

老生常谈cookie跨域

cookie, jquery, php

很早之前就做过跨域设置 cookie 的项目了,但是以前没有做好积累,今晚花了点时间重新复习一下。

OK ,有两个域名, www.a.com 和 www.b.com ,现在要通过 a 网站来设置 b 网站下的 cookie 。

a 网站下 setcookie.php 的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<html>
<head>
    <meta charset="utf-8" />
    <title>Cookie Cross Domain</title>
    <!--
    -->
    <script type="text/javascript" src="http://www.b.com/cookie/setcookie.php?name=world"></script>
</head>
<body>
    <h1>test</h1>
    <!--
    <iframe src="http://www.b.com/cookie/setcookie.php?name=hello"></iframe>
    -->
</body>
</html>

用 JavaScript 来调用或者用 iframe 调用都是没有问题的。

下面是 b 网站的 setcookie.php 的代码:

1
2
3
header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');
$name = isset($_GET['name']) ? $_GET['name'] : "caiknife";
setcookie("name", $name, time()+3600, '/', '.b.com');

第一行的header函数是因为IE浏览器下有严格的P3P安全验证,所以需要发送这段header信息,FireFox下可以不用。

接下来,是b网站的getcookie.php的代码:

1
2
3
4
5
6
if (isset($_GET['callback'])) {
    $callback = $_GET['callback'];
    echo $callback."(".json_encode($_COOKIE).")";
} else {
    echo json_encode($_COOKIE);
}

先别管if语句里前面的代码是什么意思,我们直接访问http://www.b.com/cookie/getcookie.php ,就能看到结果:{“name”:“world”},OK,cookie跨域设置成功!

接下来,是cookie跨域读取,看看a网站的getcookie.php代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
    <script type="text/javascript" src="js/jquery.min.js"></script>
    <script type="text/javascript">
    $(function(){

    $.getJSON("http://www.b.com/cookie/getcookie.php?callback=?", function(data){
        $("p").html(data.name);
        // alert(data.name);
    });

    });
    </script>
</head>
<body>
    <p></p>
</body>
</html>

这里callback=?,在jQuery的官方文档里是这么解释的:

在 jQuery 1.2 中,您可以通过使用JSONP形式的回调函数来加载其他网域的JSON数据,如 “myurl?callback=?”。jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。 注意:此行以后的代码将在这个回调函数执行前执行。”。

现在访问 a 网站的 http://www.a.com/cookie/getcookie.php 页面,看到p标签里显示了“world”,跨域 cookie 读取成功!

以上代码在 FireFox 20.0,IE9 下测试通过。

Have a nice day!