目录
什么是jsonp
首先先知道
为什么需要JSONP?
JSONP的原理
jsonp的第一种方式,将目标作为js形式加载过来,尽管其实对方是一个php
一、Ajax工作原理
二、Jsonp工作原理
三、Ajax 和 jsonp的区别
直接用jquery的ajax来请求jsonp
什么是jsonp,jsonp是什么,jsonp如何使用
由于浏览器安全限制,数据是不可以直接跨域(包括不同的根域名、二级域名、或不同的端口)请求的,除非目标域名授权你可以访问。比如设置crossdomain.xml 或在http头部里授权
但是crossdomain.xml会允许设置的网站访问所有的数据,而头部设置又非常麻烦。
所以可以在你授权的数据返回里设置jsonp来让该接口允许所有的调用者获取数据。
jsonp是使用方法回调的原理.
在网页里,你如果引入其他网页的js,那这个页面的js是可以调用你网页的代码的
直接请求js 和 请求的动态页面(jsp,php,aspx)里输出的javascript代码 效果一样
function showjson(json){ alert(json.url); }如果引用的js或动态页面里有 showjson({"url":"http://www.bejson.com"});这行代码的话,那就会弹出 http://www.bejson.com
下面我们在这个页面里来请求http://www.ibilibili.com/static/js/forbejson/userinfo.php页面的数据,这个php页面数据会有回调函数showjson,来调用我们这个bejson页面里的 showjson方法 并将一个json传入:
< ?php //这里是php页面里,回调showjson方法,这里的方法必须和上面定义的本地页面中的回调方法一致 echo 'showjson({"url":"http://www.bejson.com"})'; ?>请求又回调函数的php:
$("#getuserp").click(function(){ $.getScript("//www.bejson.com/test/userinfop.php"); });那如果我们抓包后就会看到(如上图),点击按钮后发起了一个http请求,
请求了//www.bejson.com/test/userinfop.php页面,
页面里输出了 showjson({"url":"http://www.bejson.com"}) ,
相当于在用户和服务器之间加了—个中间层(AJAX引擎),使用户操作与服务器响应异步化。对于用户请求ajax引擎会做一些数据验证和数据处理,不是所有请求都提交给服务器,当需要从服务器读取新数据时由Ajax引擎代为向服务器提交请求。AJAX最大优点就是不刷新整个页面的前提下与服务器通信维护数据。
过程:
第一步:创建一个ajax引擎对象,IE6的是new ActiveXObject,其他浏览器是new一个xmlHttpRequest对象;
第二步:调用open方法启动一个请求以备发送,open方法传入三个参数:请求类型,请求url和一个布尔值;
第三步:调用send方法发送;
第四步:处理回调函数onreadystatechange,当readState = 4 (响应数据完成),并且status=200(请求成功)时候处理响应数据。
注意:回调函数要写在open()和send()之前。
动态创建一个script标签,利用script标签src属性访问没有限制来实现跨域。
web客户端通过与调用脚本一样的方式来调用跨域服务器上动态生成的js格式文件(后缀.json),服务器动态生成json文件目的是把客户端需要的数据装入进去。
允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住json数据,这样客户端就可以随意定制自己的函数来自动处理返回数据。
1、ajax和jsonp的调用方式很像,目的一样,都是请求url,然后把服务器返回的数据进行处理,因此jquery和ext等框架都把jsonp作为ajax的一种形式进行了封装。
2、实质不同
ajax的核心是通过xmlHttpRequest获取非本页内容;
jsonp的核心是动态添加script标签调用服务器提供的js脚本(后缀.json)。
3、区别联系
ajax与jsonp的区别也不在于是否跨域。ajax禁止跨域,但通过服务端代理一样跨域;jsonp是为了解决ajax禁止跨域的问题,但jsonp并不排斥同域的数据的获取。
4、jsonp是一种方式或者说非强制性的协议,ajax也不一定非要用json格式来传递数据。
5、jsonp只支持get请求,ajax支持get和post请求。
因为是以javascript文件形式加载过来 ,所以他会对本地页面showjson发起回调(看绿色箭头),并传入json参数(看红色箭头),所以就会弹出了json中的url。
感谢葫芦指出代码错误,并提供正确代码
$.ajax({ url:'//www.bejson.com/test/userinfop.php', type:"GET", dataType:"jsonp", jsonp: false, jsonpCallback: "showjson", //这里的值需要和回调函数名一样 success:function(data){ console.log("Script loaded and executed."); }, error:function (textStatus) { //请求失败后调用的函数 console.log(JSON.stringify(textStatus)); } });本面试题为前端常考面试题,后续有机会继续完善。我是歌谣,一个沉迷于故事的讲述者。
欢迎一起私信交流。
“睡服“面试官系列之各系列目录汇总(建议学习收藏)