Json   发布时间:2022-04-22  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了浅谈 JSONP大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

什么是跨域

@H_450_17@同一域名下 @H_450_17@同一域名下不同文件夹 @H_450_17@同一域名下不同端口 @H_450_17@同一域名下不同端口 @H_450_17@域名和域名对应的IP @H_450_17@同一域名下不同协议 @H_450_17@主域相同、子域不同 @H_450_17@不同域名
URL 说明 是否允许通信
http://www.a.com/a.jshttp://www.a.com/b.js 允许
http://www.a.com/a.jshttp://www.a.com/script/b.js 允许
http://www.a.com:8000/a.jshttp://www.a.com/b.js 不允许
http://www.a.com:8000/a.jshttp://www.a.com/b.js 不允许
http://www.a.com/a.jshttp://172.16.7.93/b.js 不允许
http://www.a.com/a.jshttps://www.a.com/b.js 不允许
http://www.a.com/a.jshttps://script.a.com/b.js 不允许
http://www.a.com/a.jshttps://www.b.com/b.js 不允许

特别注意亮点:
+ 在跨域问题上,域仅仅是通过 “URL首部”来识别而不会去尝试判断相同 IP 地址对应两个域或两个域是同一个IP

什么是 JSONP

什么是同源策略

1. 建两个网页,一个端口是 8080 ,一个端口是 8081。
2. 用 jQuery 发送跨域请求
$('#redBtn').click(function() {
        $.get("http://localhost:8081/js/jquery-3.1.1.min.js",function(data) {
            console.log(data)
        })
    });

JSONP 要解决的就是这个问题。

拥有 src 属性一类 HTML 标签的跨域能力

<script type=@H_301_143@"text/javascript" src=@H_301_143@"http://localhost:8081/js/jquery-3.1.1.min.js"></script>

200,请求成功。8080端口向8081端口请求资源,通过 src 请求成功,这就是 JSONP 的基础。

利用 Script 获取 JSON 数据源

8081端口新建一个 JOSN 文件,JS 加载完

jsonpcallBACk({"Email":"issacyoung@msn.cn","Name":"Issac Young"})

从 8080 端口访问 8081 的 JSON 文件,约定俗成的再 QueryString 后加上 callBACk 参数。

<script type=@H_301_143@"text/javascript"> function jsonpcallBACk(data){ console.log(data) } function CreateScript(srC) { $("<script><//script>").attr("src",srC).appendTo("body") } $('#redBtn').click(function() { CreateScript("http://localhost:8081/jsondata.json?callBACk=jsonpcallBACk"); }); </script>

输出成功!

jQuery 获取 JSONP

上面的方式略显繁琐,庆幸的是 jQuery 已经帮我们做好的封装。

function jsonpcallBACk(data) {
        console.log(data)
    }

    $('#redBtn').click(function() {
        $.ajax({
            url: 'http://localhost:8081/jsondata.json',dataType: "jsonp",jsonp: "callBACk",success: function(data) {
                console.log(data)
            }
        })
    });

输出成功。

大佬总结

以上是大佬教程为你收集整理的浅谈 JSONP全部内容,希望文章能够帮你解决浅谈 JSONP所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:jsonp浅谈