同源谋略、跨域访问&JSONP

同源策略、跨域访问&JSONP

       JSONP(JSON with Padding)是JSON的一种“使用模式”,可用于解决主流浏览器的跨域数据访问的问题。由于同源策略,一般来说位于 server1.example.com 的网页无法与不是 server1.example.com的服务器沟通,而 HTML 的<script> 元素是一个例外。利用 <script> 元素的这个开放策略,网页可以得到从其他来源动态产生的 JSON 资料,而这种使用模式就是所谓的 JSONP。用 JSONP 抓到的资料并不是 JSON,而是任意的JavaScript,用 JavaScript 直译器执行而不是用 JSON 解析器解析。(概念来自百度)

 

jsonp格式:

 

callback({"title":"content"})
 
使用方法:
<script type="text/javascript">
    function callback(result, methodName) {
        console.log(result);
    }
</script>
<script type="text/javascript" src="http://www.night.com/reverie?jsonp=callback"></script>
 

 

JQuery 的使用方法:

 

 

<script>
$(document).ready(function(){
    $.getJSON("http://night.com/reverie?callback=?",
        function(data){
            console.log(data);
    });
});
</script>
 

 

$.ajax 的使用方法:

 

<script>
    $.ajax({
        dataType:'jsonp',
        data:'',
        jsonp:'callback',
        url:'http://www.night.com/reverie',
        success:function(data){
    	    console.log(data);
        }
    });
</script>