Vue使用Axios通过post方式访问后台,为什么后台获取不到传递过来的参数?(跨域)

发布于 2022-01-06 18:22:09 字数 732 浏览 901 评论 4

我用Vue+Element搭建了一个前端应用。使用Axios来进行数据的访问。配置如下

后台是一个Spring项目,也进行了跨域的配置,如下

使用如下代码请求后台时,后台确实接收到了请求,但却没有接收到请求参数

尝试了各种方法都不行唉.../(ㄒoㄒ)/~~

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

狠疯拽 2022-01-08 02:46:38
@RequestMapping(value="/uploadCarousel", method=RequestMethod.POST)
public ContentResults test(@RequestBody UserBean userbean) {
        
    }

 

葬花如无物 2022-01-08 02:45:16

刚踩了这个坑,浪费了大半天时间查资料。

前台用是json,后台控制器使用基础数据类型接受时就会发现参数值为空。

但是用postman测试又没问题。

解决办法

https://stackoverflow.com/questions/12893566/passing-multiple-variables-in-requestbody-to-a-spring-mvc-controller-using-ajax

 

顾忌 2022-01-08 02:41:48

第一步看手动json请求后台能不能请求到,确保后台是没问题的
第二步浏览器端看发送的请求是否符合格式,是否和第一步的一致
浏览器检查格式方法 右键/检查/Network

做个少女永远怀春 2022-01-07 23:46:13

1  , axios 默认采用的是applicaiton/json  ,应该要@requestBody 获取请求内容。(其实就是 前台POST JSON字符串 到后台)

2 , 如果spring mvc 想使用key-value这种方式接收,可以放到URL参数中(使用 这个 config.data = qs.stringify(config.data) 也可以实现)

3 ,第三种是用 用一个url的方法转换一下(具体忘记哪个方法了), 后台也可以收到,但是有浏览器兼容性问题。不推荐。

推荐第二种。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文