博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jsonp的原理?
阅读量:6890 次
发布时间:2019-06-27

本文共 1120 字,大约阅读时间需要 3 分钟。

ajax请求受同源策略影响,不允许进行跨域请求,而script标签src属性中的链接却可以访问跨域的js脚本,利用这个特性,服务端不再返回JSON格式的数据,而是返回一段调用某个函数的js代码,在src中进行了调用,这样实现了跨域。

Ajax工作原理是

相当于在用户和服务器之间加了—个中间层(AJAX引擎),使用户操作与服务器响应异步化。

对于用户请求ajax引擎会做一些数据验证和数据处理,不是所有请求都提交给服务器,当需要从服务器读取新数据时由Ajax引擎代为向服务器提交请求。AJAX最大优点就是不刷新整个页面的前提下与服务器通信维护数据。

过程的话

第一步:创建一个ajax引擎对象,ie6的是new ActiveXObject其他浏览器是new一个xmlHttpRequest对象

第二步 调用open方法启动一个请求以备发送,open方法传入三个参数 请求类型,请求url和一个布尔值

第三步 调用send方法发送

第四部 处理回调函数onreadystatechange,当readState = 4 响应数据完成时 并且2status=200请求成功的时候处理响应数据

注意:回调函数要写在open()和send()之前

Jsonp原理

动态创建一个script标签,利用script标签src属性访问没有限制,实现跨域。

web客户端通过与调用脚本一样的方式来调用跨域服务器上动态生成的js格式文件(后缀.json),服务器之所以要动态生成json文件目的把客户端需要的数据装入进去。

允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住json数据 这样客户端就可以随意定制自己的函数来自动处理返回数据

Ajax 和 jsonp的区别

1.ajax和jsonp的调用方式很像,目的一样,都是请求url,然后把服务器返回的数据进行处理,因此jquery和ext等框架都把jsonp作为ajax的一种形式进行了封装;

2.实质不同
 ajax的核心是通过xmlHttpRequest获取非本页内容
 jsonp的核心是动态添加script标签调用服务器提供的js脚本(后缀.json)
3.区别联系
 不在于是否跨域
 ajax通过服务端代理一样跨域
 jsonp也不并不排斥同域的数据的获取
4.jsonp是一种方式或者说非强制性的协议
 ajax也不一定非要用json格式来传递数据 

5.jsonp只支持get请求,ajax支持get和post请求

转载于:https://www.cnblogs.com/duanzhange/p/9325735.html

你可能感兴趣的文章
[BZOJ4404] [Neerc2015]Binary vs Decimal(BFS)
查看>>
es 剩余磁盘空间达到es最小值,添加数据被block
查看>>
第29件事 评估需求的8种方法
查看>>
安卓工程简介
查看>>
python基础===python内置函数大全
查看>>
Django form组件 与 cookie/session
查看>>
Java(Java SE7) 体系结构图
查看>>
安装多个版本的unity
查看>>
Unity 脚本的未来发展
查看>>
给vs2010安装上cocos2d-x的模版
查看>>
ffmpeg-20160908[09,10,13,15,19,21,22,24]-bin.7z
查看>>
【java】java处理随机浮点数(小数点后两位)用RMB的大写数值规则输出
查看>>
jquery键盘事件
查看>>
MFC学习之EDIT控件初始化
查看>>
luogu P1972 [SDOI2009]HH的项链 树状数组
查看>>
关于UWP数据绑定的一个坑 x:bind修改为binding
查看>>
线程的状态
查看>>
IDEA小插件之快速修改Maven多模块的工程版本
查看>>
Programming C#.Classes and Objects.成员方法
查看>>
《大道至简》读后感03
查看>>