Vue中axios发送GET请求:如何正确传递数组参数给Spring Boot后端?

Vue中axios发送GET请求:如何正确传递数组参数给Spring Boot后端?

本文探讨在vue.js项目中,使用axios发送get请求时,如何正确传递数组参数到spring boot后端的问题。

问题:

开发者试图通过axios的GET请求,将一个前端数组this.searchRoomTags传递给后端/searchRoomTags接口。前端代码如下:

this.$axios    .get('/searchRoomTags', {      params: {        pageSize: this.roomPageInfo.pageSize,        roomType: encodeURI(this.roomForm.roomType),        roomTags: this.searchRoomTags,        roomState: this.searchContent      }    })    .then(Response => {      if (Response.data) {        this.searchSuccessHandle(Response)      }    })

后端Spring Boot代码:

@CrossOrigin@GetMapping("/searchRoomTags")@ResponseBodypublic PageInfo searchRoomTags(@RequestParam String[] roomTags, Rooms room, HttpServletRequest request) {    logger.info("用户开始根据房间标签进行查找————————");    request.getSession().removeAttribute("condition");    room.setCurrentPage(1);    System.out.println("roomTags:" + roomTags);    PageInfo pageInfo = null;    logger.info("客房查询成功!");    return pageInfo;}

运行时,前端抛出java.lang.IllegalArgumentException异常,提示URL中存在无效字符。这是因为Spring Boot无法正确解析GET请求中的数组参数。

立即学习“前端免费学习笔记(深入)”;

原因及解决方案:

GET请求参数通过URL拼接传递,URL对数组参数的处理方式与普通参数不同。直接传递数组会导致URL中出现多个同名参数(例如roomTags[]=值1&roomTags[]=值2),违反HTTP规范,从而引发解析错误。

解决方案是将数组转换为URL可识别的格式,例如用逗号分隔的字符串。修改后的前端代码:

this.$axios    .get('/searchRoomTags', {      params: {        pageSize: this.roomPageInfo.pageSize,        roomType: encodeURI(this.roomForm.roomType),        roomTags: (this.searchRoomTags || []).join(','),        roomState: this.searchContent      }    })    .then(Response => {      if (Response.data) {        this.searchSuccessHandle(Response)      }    })

此代码将this.searchRoomTags数组用逗号连接成字符串。后端代码也需修改,将@RequestParam String[] roomTags改为@RequestParam String roomTags,并在后端使用逗号分割字符串来还原数组。 这既保证了URL规范性,也简化了后端数据处理。

以上就是Vue中axios发送GET请求:如何正确传递数组参数给Spring Boot后端?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1561945.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 06:57:55
下一篇 2025年12月22日 06:58:09

相关推荐

发表回复

登录后才能评论
关注微信