jsonp跨域访问php,jsonp跨域访问的分析(前端和后端)

本篇文章给大家带来的内容是关于jsonp跨域访问的分析(前端和后端),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

一、什么是跨域访问

举个栗子:在A网站中,我们希望使用Ajax来获得B网站中的特定内容。如果A网站与B网站不在同一个域中,那么就出现了跨域访问问题。你可以理解为两个域名之间不能跨过域名来发送请求或者请求数据,否则就是不安全的。跨域访问违反了同源策略,同源策略的详细信息可以点击如下链接:Same-origin_policy;

总而言之,同源策略规定,浏览器的ajax只能访问跟它的HTML页面同源(相同域名或IP)的资源。

二、什么是JSONP

JSONP(JSON with Padding)是JSON的一种“使用模式”,可用于解决主流浏览器的跨域数据访问的问题。

由于同源策略,一般来说位于 server1.example.com 的网页无法与不是 server1.example.com的服务器沟通,而 HTML 的

三、JSONP的使用

前端的使用示例

JQuery Ajax对JSONP进行了很好的封装,我们使用起来很方便。前端示例:$.ajax({

type:"GET",

url:"http://www.deardull.com:9090/getMySeat", //访问的链接

dataType:"jsonp", //数据格式设置为jsonp

jsonp:"callback", //Jquery生成验证参数的名称

success:function(data){ //成功的回调函数

alert(data);

},

error: function (e) {

alert("error");

}

});

需要注意的地方是:dataType,该参数必须要设置成jsonp

jsonp,该参数的值需要与服务器端约定,详细情况下面介绍。(约定俗成的默认值为callback)

后端的配合示例

JQuery Ajax Jsonp原理

后端要配合使用jsonp,那么首先得了解Jquery Ajax jsonp的一个特点:

Jquery在发送一个Ajax jsonp请求时,会在访问链接的后面自动加上一个验证参数,这个参数是Jquery随机生成的,例如链接

http://www.deardull.com:9090/getMySeat?callback=jQuery31106628680598769732_1512186387045&_=1512186387046

中,参数callback=jQuery31106628680598769732_1512186387045&_=1512186387046就是jquery自动添加的。

添加这个参数的目的是唯一标识这次请求。当服务器端接收到该请求时,需要将该参数的值与实际要返回的json值进行构造(如何构造下面讲解),并且返回,而前端会验证这个参数,如果是它之前发出的参数,那么就会接收并解析数据,如果不是这个参数,那么就拒绝接受。

需要特别注意的是这个验证参数的名字(我在这个坑上浪费了2小时),这个名字来源于前端的jsonp参数的值。如果把前端jsonp参数的值改为“aaa”,那么相应的参数就应该是

aaa=jQuery31106628680598769732_1512186387045&_=1512186387046

后端接收与处理

知道了Jquery Ajax Jsonp的原理,也知道了需要接受的参数,我们就可以来编写服务器端程序了。

为了配合json,服务器端需要做的事情可以概括为两步:

第一步、接收验证参数

根据与前端Ajax约定的jsonp参数名来接收验证参数,示例如下(使用SpringMVC,其他语言及框架原理类似)@ResponseBody

@RequestMapping("/getJsonp")

public String getMySeatSuccess(@RequestParam("callback") String callback){

第二步、构造参数并返回

将接收的的验证参数callback与实际要返回的json数据按“callback(json)”的方式构造:@ResponseBody

@RequestMapping("/getMySeat")

public String getMySeatSuccess(@RequestParam("callback") String callback){

Gson gson=new Gson(); //google的一个json工具库

Map map=new HashMap<>();

map.put("seat","1_2_06_12");

return callback+"("+gson.toJson(map)+")"; //构造返回值

}

四、总结

最终,前后端的相应代码应该是这样的:

前端$.ajax({

type:"GET",

url:"http://www.deardull.com:9090/getMySeat", //访问的链接

dataType:"jsonp", //数据格式设置为jsonp

jsonp:"callback", //Jquery生成验证参数的名称

success:function(data){ //成功的回调函数

alert(data);

},

error: function (e) {

alert("error");

}

});

后端@ResponseBody

@RequestMapping("/getMySeat")

public String getMySeatSuccess(@RequestParam("callback") String callback){

Gson gson=new Gson();

Map map=new HashMap<>();

map.put("seat","1_2_06_12");

logger.info(callback);

return callback+"("+gson.toJson(map)+")";

}

需要注意的是:前端注意与后端沟通约定jsonp的值,通常默认都是用callback。

后端根据jsonp参数名获取到参数后要与本来要返回的json数据按“callback(json)”的方式构造。

如果要测试的话记得在跨域环境(两台机器)下进行。

完整的示例就是上面两段代码,亲测有效。

相关推荐:

以上就是jsonp跨域访问的分析(前端和后端)的详细内容,更多请关注php中文网其它相关文章!

article_wechat2021.jpg?1111

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值