码迷,mamicode.com
首页 > Web开发 > 详细

JS的跨域理解

时间:2016-04-13 18:46:34      阅读:146      评论:0      收藏:0      [点我收藏+]

标签:

前言

  周一的学院点开题被批的很惨,换了个校长,各种被抓严,班上已经有两个同学打算休学了。哎,这周的聚会可能是大家集聚的最后一次吧。熬着吧,还是学习我的前端,不管老板学校咋逼了,找个好工作才是王道。今天把学习的几种跨域方法做个小结吧,不然就很容易忘了。

什么是跨域?

JavaScript处于安全方面的考虑,不允许跨域调用其他页面的对象。也就是说a.com域名下的JS无法操作b.com或者c.a.com域名下的对象。JS跨域就是要解决在不同的域之间的数据传输或通信。只要是协议、域名、端口有任何一个的不同,都被当做是不同的域。如下所示:

技术分享

JSONP跨域

JsonP跨域是我们最常见的跨域方法,它所基于的原理:直接通过XMLHttpRequest是不能请求不同域的数据,但是我们可以在页面中引入不同域的JS文件。

假设a.html页面里面要获取http://b.com/data.php里面的json数据。那么我们可以在a.html页面中可以这样实现:

<script>
    function cb(jsondata){
        //处理获得的json数据
    }
</script>
<script src="http://b.com/data.php?callback=cb"></script>

在创建的script标签里src的url后面有个?callback=cb,这里cb就是我们获取数据后要执行的函数。

在data.php里面,返回的必须是一段可执行的JS文件。如下:

<?php
    $callback = $_GET[callback]; //得到回调函数名cb
    $data = array(a,b,c);  //返回的数据
    echo $callback.(.json_encode($data).);
?>

最终a.html页面得到的结果是cb([‘a‘,‘b‘,‘c‘])。这就得到我们想要的数据了。

  

 

JS的跨域理解

标签:

原文地址:http://www.cnblogs.com/wait-hua/p/4533806.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!