为了账号安全,请及时绑定邮箱和手机立即绑定

spring后台和jsonp解决跨域问题

标签:
Java

为什么会发生AJAX跨域

1.浏览器限制
2.跨域 :协议 域名 端口
3.XHR(xmlhttprequest)请求才会报跨域问题

同时满足以上3點才会产生跨域安全问题

解決思路

图片描述

使用jsonp

原因:不使用XHR(xmlhttprequest)请求

前端代码

$.ajax({
	    	url : interfaceUrl,
	        type : "get",
	        dataType : "jsonp",
	        data : paramObj,
	        jsonp: "callbackparam",
	        jsonpCallback: "success_jsonpCallback",
	        success : function(result) {
	        ……
	        }

后端代码

@GetMapping(value = "/map", produces = {"application/javascript;charset=UTF-8"})
    @ResponseBody
    @ApiOperation("根据用户id查询轨迹图")
    public String getTrackMap(@RequestParam(value = "callbackparam") String callback) {
        String str = "……";
        return callback + "(" + str + ")";
    }

这里要注意两点,

1.produces = {“application/javascript;charset=UTF-8”}

返回类型为javascript

2.return callback + “(” + str + “)”

获取前端传递的callback参数并拼接需要给前端的数据

结果

图片描述

可以通过在ajax中在控制台打印"result"参数来观察获取的数据!

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消