前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >json和jsonp的使用区别

json和jsonp的使用区别

作者头像
全栈程序员站长
发布于 2022-07-08 02:31:49
发布于 2022-07-08 02:31:49
64000
代码可运行
举报
运行总次数:0
代码可运行

一. 跨域请求的概念

  JavaScript出于安全方面的考虑,不允许跨域调用其他页面的对象。

二. json和jsonp

  JSON是一种基于文本的数据交换方式(不支持跨域),而JSONP是一种非官方跨域数据交互协议。

  使用json格式传递数据的客户端代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 $(function () {  2 var user = {  3 "username": "HelloWorld"  4  };  5  6  $.ajax({  7 url: "http://localhost:8080/Changyou/UserInfo",  8 type: "POST",  9 contentType: "application/json; charset=utf-8", 10 dataType: "json", //json不支持跨域请求,只能使用jsonp 11  data: { 12  user: JSON.stringify(user) 13  }, 14 success: function (data) { 15 $("#user_name")[0].innerHTML = data.user_name; 16 $("#user_teleNum")[0].innerHTML = data.user_teleNum; 17 $("#user_ID")[0].innerHTML = data.user_ID; 18  }, 19 error: function () { 20 alert("请求超时错误!"); 21  } 22  }) 23 });

  然而,简单地使用json并不能支持跨域资源请求,为了解决这个问题,需要采用jsonp数据交互协议。众所周知,js文件的调用不受跨域与否的限制,因此如果想通过纯web端跨域访问数据,只能在远程服务器上设法将json数据封装进js格式的文件中,供客户端调用和进一步处理,这就是jsonp协议的原理。该协议的一个要点就是允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。

  简单的说,就是json不支持跨域,而js可以跨域,因此在服务器端用客户端提供的js函数名将json数据封装起来,再将函数提供给客户端调用,从而获得json数据。

  开发过程中,如果出现类似 “Origin ****** is not allowed by Access-Control-Allow-Origin.” 的错误,则可能是由于json数据不支持跨域导致的,应考虑使用jsonp协议。

  如果出现类似 ”SyntaxError: Unexpected token ‘:’. Parse error.“ 的错误,则可能是由于返回的json数据没有用”callback“传递的函数名封装导致的。

  客户端代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 $(function () {  2  3 var user = {  4 "username": "HelloWorld"  5  };  6  7  $.ajax({  8 url: "http://localhost:8080/Changyou/UserInfo",  9 type: "POST", 10 contentType: "application/json; charset=utf-8", 11 dataType: "jsonp", //json不支持跨域请求,只能使用jsonp 12  data: { 13  user: JSON.stringify(user) 14  }, 15 jsonp: "callback", //传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名,默认为callback 16 jsonpCallback: "userHandler", //自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据 17 success: function (data) { 18 $("#user_name")[0].innerHTML = data.user_name; 19 $("#user_teleNum")[0].innerHTML = data.user_teleNum; 20 $("#user_ID")[0].innerHTML = data.user_ID; 21  }, 22 error: function () { 23 alert("请求超时错误!"); 24  } 25  }) 26 });

  服务器端代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 1 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  2 response.setContentType("application/json; charset=utf-8");  3 String username = new String(request.getParameter("user").getBytes("ISO-8859-1"),"utf-8");  4 String callback = new String(request.getParameter("callback").getBytes("ISO-8859-1"),"utf-8");  5 System.out.println("接收到的数据:" + username);  6 System.out.println("callback的值:" + callback);  7 JSONObject user = JSONObject.fromObject(username);  8 System.out.println("接收到的用户名:" + user.get("username"));  9 JSONObject userinfo = new JSONObject(); 10 userinfo.put("user_name", "张鸣晓"); 11 userinfo.put("user_teleNum", "18810011111"); 12 userinfo.put("user_ID", "123456789098765432"); 13 PrintWriter out = response.getWriter(); 14 String backInfo = callback + "(" + userinfo.toString() + ")"; //将json数据封装在callback函数中提供给客户端 15  out.print(backInfo); 16  out.close(); 17 }

尽管客户端没有实现userHandler函数,但也能成功运行,原因就是jquery在处理jsonp类型的ajax时,自动帮你生成回调函数并把数据取出来供success属性方法来调用。

更详细解释,参见http://kb.cnblogs.com/page/139725/

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/112526.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年11月,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
JSONP原理以及示例(jsonp示例)
首先我们需要明白,在页面上直接发起一个跨域的ajax请求是不可以的,但是,在页面上引入不同域上的js脚本却是可以的,就像你可以在自己的页面上使用<img src=””> 标签来随意显示某个域上的图片一样。比如我在8080端口的页面上请求一个9090端口的图片:
超级小可爱
2024/02/20
4220
JSONP原理以及示例(jsonp示例)
前端跨域原理以及跨域解决方案
是不是又看到了熟悉的 No 'Access-Control-Allow-Origin' (这是跨域的经典标志), 惊不惊喜,意不意外,是不是很熟悉!
胡哥有话说
2019/07/25
1.1K0
前端跨域原理以及跨域解决方案
jsonp介绍与jsonp封装
首先说个很多刚接触的人都想问的问题:     jsonp到底是什么? (看完本篇文章你就知道了) ---- 1、一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面、动态网页、web服务、WCF,只要是跨域请求,一律不准; 2、不过我们又发现,Web页面上调用js文件时则不受是否跨域的影响(不仅如此,我们还发现凡是拥有”src”这个属性的标签都拥有跨域的能力,比如<script>、<img>、<iframe>); 3、于是可以判断,当前阶段如果想通过纯w
游魂
2018/06/08
2.3K0
ajax跨域请求jsonp完整示例
最经用到jsonp(ajax)的跨域请求,在这分享给大家,有需要用到的一看就能明白。具体步骤如下:
全栈程序员站长
2022/07/05
6960
ajax跨域请求jsonp完整示例
详析JSONP跨域
关于跨域这个问题也是大家工作中经常遇到的问题,之前给大家讲解了跨域的基本知识以及如何使用iframe跨域,如果想具体了解iframe跨域可以点击:深入剖析iframe跨域问题。本文主要讲解JSONP的原理,以及JSONP的实际应用。 JSONP的详析流程: 1 什么是JSONP 2 JSONP的原理与实现流程 2.1 JSONP跨域流程 2.2 相关提示 3 JSONP的实例 - 辅助理解JSONP流程 3.1 JSONP跨域实例 - 前端的JS代码 3.2 JSONP跨域实例 - 后台的PHP代码 3.3
HTML5学堂
2018/03/13
1.9K0
详析JSONP跨域
ajax跨域请求结合springmvc后台代码学习整理
ajax跨域请求,在工作中遇到使用ajax发起请求获取数据,但是请求的数据不在同一个域下,这样子就要使用到ajax的跨域请求了! 我使用的框架 SpringMVC,我在PC端的项目里面写一个接口方法,但是在wap项目中也要用改接口!下面贴出示例代码: (1):前台请求代码 ①:正常请求(不跨越)
全栈程序员站长
2022/07/19
3840
AJAX跨域请求JSONP 原
JSONP(JSON with Padding)是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问(这仅仅是JSONP简单的实现形式)。
tianyawhl
2019/04/04
9640
jsonp温故
更新说明:对文章排版以及内容格式做了调整。 更新时间:2022-05-04 今天重新学习之前写了半截的项目,其中提到了jsonp,当时也是查了很多资料,做了很多笔记,但是最近在写一个项目的时候,竟然遗忘了很多,所以特此做个总结,在下次再遇到jsonp的时候,可以有一个清晰的认识。 jsonp原理介绍 jsonp就是为了解决前端的跨域问题而进行的一项设计,jsonp之所以能实现跨域,是因为它发送的不是ajax请求,它动态创建了script标签,script标签是不受同源策略限制的,将script
六个周
2022/10/28
5270
Jsonp
方案一:在Controller中取cookie中的token数据,调用sso服务查询用户信息。
用户5927264
2019/08/01
8290
js ajax 跨域问题 解决方案[通俗易懂]
跨域问题来源于JavaScript的”同源策略”,即只有 协议+主机名+端口号 (如存在)相同,则允许相互访问。也就是说JavaScript只能访问和操作自己域下的资源,不能访问和操作其他域下的资源。跨域问题是针对JS和ajax的,html本身没有跨域问题。
全栈程序员站长
2022/09/25
1.8K0
js ajax 跨域问题 解决方案[通俗易懂]
json & jsonp
对于JSON和JSONP,应该都不陌生,咳咳,不过最初对JSONP有点误解,以为是JSON的另外一个别名,其实二者风马牛不相及。
仇诺伊
2018/09/12
1.3K0
json & jsonp
CORS和JSONP跨域漏洞学习知识点
不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源。只有同一个源的脚本才可以赋予dom、读写cookie、session、ajax等操作的权限,例如a.com可以随意调用b.com的接口去修改数据
UzJu@菜菜狗
2022/04/25
5610
CORS和JSONP跨域漏洞学习知识点
说说JSON和JSONP,也许你会豁然开朗-转
今天在写底层通信框架的时候,遇到了跨域的问题;随便给不知道的童鞋们分享下基础知识。 前言   由于Sencha Touch 2这种开发模式的特性,基本决定了它原生的数据交互行为几乎只能通过AJAX来实现。   当然了,通过调用强大的PhoneGap插件然后打包,你可以实现100%的Socket通讯和本地数据库功能,又或者通过HTML5的WebSocket也可以实现与服务器的通讯和服务端推功能,但这两种方式都有其局限性,前者需要PhoneGap支持,后者要求用户设备必须支持WebSocket,因此都
李海彬
2018/03/19
1.7K0
说说JSON和JSONP,也许你会豁然开朗-转
jsonp跨域原理简单总结_jsonp的工作原理
JavaScript这个安全策略在进行多iframe或多窗口编程、以及Ajax编程时显得尤为重要。
全栈程序员站长
2022/11/17
2.1K0
JSONP原理及使用
首先提一下JSON这个概念,JSON是一种轻量级的数据传输格式,被广泛应用于当前Web应用中。JSON格式数据的编码和解析基本在所有主流语言中都被实现,所以现在大部分前后端分离的架构都以JSON格式进行数据的传输。
yaphetsfang
2020/07/30
7990
JSONP原理及使用
JSON与JSONP的区别
说到AJAX就会不可避免的面临两个问题,第一个是AJAX以何种格式来交换数据?第二个是跨域的需求如何解决?这两个问题目前都有不同的解决方案,比如数据可以用自定义字符串或者用XML来描述,跨域可以通过服务器端代理来解决。
前端_AWhile
2019/08/29
1.8K0
解决浏览器跨域限制方案之JSONP
JSONP即:JSON with Padding,是一种解决因浏览器跨域限制不允许访问跨域资源的方法。 JSONP是一个非官方的协议,它允许在服务器端返回javascript标签到浏览器,在浏览器端通过调用javascript函数的形式实现访问跨域资源或数据。
编程随笔
2019/09/11
1.2K0
解决浏览器跨域限制方案之JSONP
Json和Jsonp
  JSON和JSONP虽然只有一个字母的差别,但其实他们根本不是一回事儿:JSON是一种数据交换格式,而JSONP是一种依靠开发人员的聪明才智创造出的一种非官方跨域数据交互协议。
aehyok
2018/09/11
1.5K0
Json和Jsonp
说说JSON和JSONP( 含jquery例子)
说到AJAX就会不可避免的面临两个问题,第一个是AJAX以何种格式来交换数据?第二个是跨域的需求如何解决?这两个问题目前都有不同的解决方案,比如数据可以用自定义字符串或者用XML来描述,跨域可以通过服务器端代理来解决。 但到目前为止最被推崇或者说首选的方案还是用JSON来传数据,靠JSONP来跨域。而这就是本文将要讲述的内容。 JSON和JSONP虽然只有一个字母的差别,但其实他们根本不是一回事儿:JSON是一种数据交换格式,而JSONP是一种依靠开发人员的聪明才智创造出的一种非官方跨域数据交互协议。我们拿
java达人
2018/01/31
1.6K0
如何理解jsonp的原理
这是因为浏览器基于同源策略,在同源策略下浏览器不允许AjAX跨域获取服务器数据 同源策略是浏览器的安全策略,指的是请求URL地址中的协议,域名和端口都与当前发送请求的页面相同,只要一处不同就是跨域请求。
切图仔
2022/09/08
4810
如何理解jsonp的原理
相关推荐
JSONP原理以及示例(jsonp示例)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验