加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

跨域访问解决方案:JSONP

发布时间:2020-12-16 18:56:55 所属栏目:百科 来源:网络整理
导读:关于什么是跨域请求,可以参见我之前的博文:http://www.cnblogs.com/LiuChunfu/p/5240145.html 上述博文最后有提到解决方案,一直说补充,但是工作忙忘了,直到朋友问起这个问题,协助解决后,才想起来这么一回事。 通常来说跨域请求可以有2种解决方案,一

关于什么是跨域请求,可以参见我之前的博文:http://www.cnblogs.com/LiuChunfu/p/5240145.html

上述博文最后有提到解决方案,一直说补充,但是工作忙忘了,直到朋友问起这个问题,协助解决后,才想起来这么一回事。

通常来说跨域请求可以有2种解决方案,一个是利用同域的后台服务器请求后,在转发,二是利用JSONP.

今天只谈谈JSONP,JSONP其中的Padding恰好是包裹的意思。JSONP就是包裹JSON的意思哦,就是在JSON外面包裹一层的意思。

一、前端请求

JSONP类型的请求:

<script type="text/javascript"> $.ajax({ url:"http://localhost:8080/JsonTest/servlet/MyJson?callback=run",dataType:"jsonp",//关键部分1:指定返回类型为jsonp
                jsonpCallback:"run",//关键部分2:指定回调的方法是run
                success:function(data){ console.info(data.name); alert(data.name); } }); </script>

二、后台响应

String callback=request.getParameter("callback");
String json="{'name':'LCF'}"; response.getWriter().write(callback+"("+json+")");

这样在前台接收到的被包裹的JSON如下所示:

run({'name':'LCF'})

结合JSONP请求中的关键部分2,明确了回调的方式是run,可以理解为ajax自动的去找到了run包裹的内容。将其中的内容转为JSON对象。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读