目录

什么是jsonp

首先先知道

为什么需要JSONP?

JSONP的原理

jsonp的第一种方式,将目标作为js形式加载过来,尽管其实对方是一个php

一、Ajax工作原理

二、Jsonp工作原理

三、Ajax 和 jsonp的区别

直接用jquery的ajax来请求jsonp


什么是jsonp

什么是jsonp,jsonp是什么,jsonp如何使用

首先先知道

  1. jsonp的核心原理就是目标页面回调本地页面的方法,并带入参数
  2. 我们常用的动态页面有jsp,php,aspx

为什么需要JSONP?

由于浏览器安全限制,数据是不可以直接跨域(包括不同的根域名、二级域名、或不同的端口)请求的,除非目标域名授权你可以访问。比如设置crossdomain.xml 或在http头部里授权

但是crossdomain.xml会允许设置的网站访问所有的数据,而头部设置又非常麻烦。

所以可以在你授权的数据返回里设置jsonp来让该接口允许所有的调用者获取数据。

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

jsonp的第一种方式,将目标作为js形式加载过来,尽管其实对方是一个php

下面我们在这个页面里来请求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最大优点就是不刷新整个页面的前提下与服务器通信维护数据。

过程:

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

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

第三步:调用send方法发送;

第四步:处理回调函数onreadystatechange,当readState = 4 (响应数据完成),并且status=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的区别也不在于是否跨域。ajax禁止跨域,但通过服务端代理一样跨域;jsonp是为了解决ajax禁止跨域的问题,但jsonp并不排斥同域的数据的获取。

4、jsonp是一种方式或者说非强制性的协议,ajax也不一定非要用json格式来传递数据。

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

因为是以javascript文件形式加载过来 ,所以他会对本地页面showjson发起回调(看绿色箭头),并传入json参数(看红色箭头),所以就会弹出了json中的url。

直接用jquery的ajax来请求jsonp

感谢葫芦指出代码错误,并提供正确代码

 $.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));}
});      

本面试题为前端常考面试题,后续有机会继续完善。我是歌谣,一个沉迷于故事的讲述者。

欢迎一起私信交流。

“睡服“面试官系列之各系列目录汇总(建议学习收藏)

“约见”面试官系列之常见面试题第十五篇之jsonp(建议收藏)相关推荐

  1. “约见”面试官系列之常见面试题第二十五篇之对vue-router的理解(建议收藏)

    先整体展示下vue-router使用方式,请牢记一下几步哦! import Vue from 'vue' import VueRouter from 'vue-router' //注册插件 如果是在浏 ...

  2. “约见”面试官系列之常见面试题第二十九篇之Vue和React的区别

    vue与react的不同之处是什么?下面本篇文章就来给大家介绍一下.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. vue与react,两者都为当下主流框架 相同之处在于: 使用 V ...

  3. “约见”面试官系列之常见面试题第二十八篇之vue中的混合(minix)实例理解

    minix 是个什么东西, 就是混合,把你混合给我 浅显表述就是 你说 : '我叫李四', 我说 : '我叫张三', 然后把你 混合给我, 就成了 我说 : '我叫张三我叫李四', 所有解说都在例子里 ...

  4. “约见”面试官系列之常见面试题第二十四篇之vue-router使用(建议收藏)

    开发的时候有时候会遇到一种情况,比如 :点击这个链接跳转到其他组件的情况,通常会跳转到新的页面,蛋是,我们不想跳转到新页面,只在当前页面切换着显示,那么就要涉及到路由的嵌套了,也可以说是子路由的使用. ...

  5. “约见”面试官系列之常见面试题第二十二篇之函数闭包(建议收藏)

    目录 1.概念 2.特点 3.闭包的创建:­­­ ---------------------------------------------我是容易看懂的分界线-------------------- ...

  6. “约见”面试官系列之常见面试题第十九篇之数组去重(建议收藏)

    目录 数组去重的方法 一.利用ES6 Set去重(ES6中最常用) 二.利用for嵌套for,然后splice去重(ES5中最常用) 三.利用indexOf去重 四.利用sort() 五.利用对象的属 ...

  7. “约见”面试官系列之常见面试题第十八篇之深拷贝和浅拷贝得区别(建议收藏)

     壹 ❀ 引 如何区分深拷贝与浅拷贝,简单点来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝,拿人手短,如果B没变,那就是深拷贝,自食其力. 此篇文章中也会简 ...

  8. “约见”面试官系列之常见面试题第十六篇之http(建议收藏)

    HTTP(Hyper Text Transfer Protocol(超文本传输协议))是一个简单的请求-响应协议,它通常运行在 TCP 之上.它指定了客户端可能发送给服务器什么样的消息以及得到什么样的 ...

  9. “约见”面试官系列之常见面试题第十四篇之所有数据类型(建议收藏)

    最近有很多人说数据类型是 6种.我怎么记得JS的数据类型有8种.最近发现好多人对JS的基础不太了解.很多数据类型都没有搞清楚.不BB,我就按我的理解写一波笔记,每次看一波书我就感觉一次比一次多懂一点. ...

最新文章

  1. Eigen 学习笔记
  2. [翻译] JTCalendar
  3. jvm性能调优 - 14JVM的老年代垃圾回收器CMS原理
  4. context存放内容_Go语言爱好者周刊:第 58 期—关于 context
  5. 软件工程导论个人项目 -- 中小学数学卷子自动生成程序
  6. java dispatchevent_java事件处理机制
  7. (43)Verilog HDL 二分频设计
  8. 【STM32】 STM32驱动URM04超声波测距模块
  9. macbook系统安装服务器,SVN-Mac安装服务器
  10. JQuery选择器跨frame和层次选择
  11. java技术不行有复试怎么办_复试答不上来怎么办?记住这四点不慌!
  12. Pandas——数据可视化
  13. python3 socket sendall_全网最详细python中socket套接字send与sendall的区别
  14. 教学案例 计算机,计算机教学案例
  15. 那些逃离北上广的人后悔吗,有过遗憾吗?
  16. Matlab程序——3d玫瑰
  17. 微信小程序 延时执行 设置固定时间间隔
  18. 微信分销商城如何推广比较吸引粉丝
  19. Hadoop2.x与3.x的区别:
  20. 2021 icpc 沈阳 J-Luggage Lock

热门文章

  1. Echarts地图编写
  2. iOS使用自定义字体(添加字体包)
  3. HDU 1213 How Many Tables(并查集模板)
  4. Android add external jar
  5. 砂.随笔.二十.微笑
  6. php 系统平均负载,Linux_解析Linux系统的平均负载概念,一、什么是系统平均负载(Load a - phpStudy...
  7. python函数的作用降低编程复杂度_Python语言程序设计 (第11期) 测验5: 函数和代码复用...
  8. mysql安装设置数据目录下,linux下安装mysql数据+配置
  9. alpha值计算 qcolor_量化交易与机器学习(四):如何研究alpha因子
  10. python变量输出到文件_使用函数将多个变量写入文件