• JSONP原理及实现跨域方式


    今天做页面时,后台给了个接口:https://a.a.com/a/a.json,我页面的上线地址是:http://b.b.com
    显而易见,因为浏览器同源策略的限制,通过ajax无法无法取得json的数据。

    百度百科

    同源策略,它是由Netscape提出的一个著名的安全策略。现在所有支JavaScript的浏览器都会使用这个策略。

        所谓同源是指,域名,协议,端口相同。当一个浏览器的两个tab页中分别打开来 百度和谷歌的页面当浏览器的百度tab页执行一个脚本的时候会检查这脚本是属于哪个页面的,即检查是否同源,只有和百度同源的脚本才会被执行。
    
    

    同源策略限制了我们无法通过原生的XMLHttpRequest()对象获取到json数据。为了突破这个限制,我们的前辈们想出了一个解决方案:jsonp。

    jsonp并非新的数据格式,而是解决JSON跨域获取的解决方案。通过JSONP获取到得数据已经不是JSON了,而是JS类型的数据(大部分是对象)。

    上网找过很多讲jsonp的文章,大部分都是讲的模模糊糊的。jsonp的原理其实不复杂:

       1、浏览器的同源策略把跨域请求都禁止了;
       2、HTML的<script>标签是例外,可以突破同源策略从其他来源获取数据;
       3、由上可得,我们可以通过<script>标签引入jsonp文件,然后通过一系列JS操作获取数据。
    

    上面三点便是JSONP实现跨域的原理。

    原理我们知道了,该怎么实现这些操作呢?
    接下来轮到jQuery登场!JQ已经帮我们封装好了
    demo:

            $.ajax({
                dataType:'jsonp',
                jsonp:'jsonp_callback',
                url:'http://www.baidu.com/xxx.jsonp',
                success:function(){
                    //dosomthing
                }
            });
    

    原生JS demo:

        function( url ) jsonHandle{
            var script = document.createElement("script");
            script.setAttribute("src",url);
            document.getElementsByTagName("body")[0].appendChild(script);
        }
        //JS插入之后就可以处理数据了

    一,接口返回

    liudehua(["zhangsan","lisi","wangwu"]);

    二,jsonpCallback 指明回调方法名字

    三,利用success,定义jsonpCallback方法. 

    示意代码:

    var jsonpCallback-Name = success;

    四,调用 jsonCallback-Name方法.

  • 相关阅读:
    ORACLE 循环
    C#生成指定数目的互不相同的随机数(转)
    Oracle自治事务的介绍
    螺旋矩阵--我的实现方法
    一个体育生的编程之路(一)
    判断十二星座——我的算法,大家看是不是比较简便
    简单的排序算法——插入排序,选择排序,交换排序(冒泡排序,快速排序)
    使用VC和DirectShow从摄像头中读取图像(一)
    1999那个追着打我的女生
    我自己写的几个C++常用方法
  • 原文地址:https://www.cnblogs.com/ExMan/p/7027649.html
Copyright © 2020-2023  润新知