JSONP跨域调用的原理
来源:互联网 发布:napa软件性能 编辑:程序博客网 时间:2024/06/05 00:53
原文链接:https://www.zhihu.com/question/19966531
很简单,就是利用<script>标签没有跨域限制的“漏洞”(历史遗迹啊)来达到与第三方通讯的目的。当需要通讯时,本站脚本创建一个<script>元素,地址指向第三方的API网址,形如:
<script src="http://www.example.net/api?param1=1¶m2=2"></script>并提供一个回调函数来接收数据(函数名可约定,或通过地址参数传递)。
第三方产生的响应为json数据的包装(故称之为jsonp,即json padding),形如:
callback({"name":"hax","gender":"Male"})
这样浏览器会调用callback函数,并传递解析后json对象作为参数。本站脚本可在callback函数里处理所传入的数据。
补充:“历史遗迹”的意思就是,如果在今天重新设计的话,也许就不会允许这样简单的跨域了嘿,比如可能像XHR一样按照CORS规范要求服务器发送特定的http头。
$('#douban').blur(function() { var douban = $(this) var id = douban.val() if (id) { $.ajax({ url: 'https://api.douban.com/v2/movie/subject/' + id, cache: true, type: 'get', dataType: 'jsonp', crossDomain: true, jsonp: 'callback', success: function(data) { $('#inputTitle').val(data.title) $('#inputDoctor').val(data.directors[0].name) $('#inputCountry').val(data.countries[0]) $('#inputPoster').val(data.images.large) $('#inputYear').val(data.year) $('#inputSummary').val(data.summary) } }) } }) })
0 0
- JSONP跨域调用的原理
- jsonp跨域原理
- JSONP跨域原理
- JSONP跨域原理
- jsonp跨域原理
- jsonp跨域调用
- jsonp 跨域调用
- jsonp实现跨越js调用的原理
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- JSONP跨域的原理解析
- [IT]JSONP跨域的原理解析
- JSONP跨域的原理解析
- 用十年学习编程 / Teach Yourself Programming in Ten Years
- oralce 常用日期函数
- 随机梯度下降法
- Xcode 真机调试:While reading /Users/wangan/Documents/..../bg.png pngcrush caught libpn
- 全面理解HTTP
- JSONP跨域调用的原理
- GCD创建线程基础
- 「Githug」Git 游戏通关流程
- Verilog中的参数例化和重定义
- StringUtils方法全集
- hdu 1848 Fibonacci again and again (FIB博弈)
- 数据结构实验之串一:KMP简单应用
- 如何清除adf table组件字段上面自带的filter过滤条件
- maven 项目中使用 jstl标签