Vue中axios GET请求:如何正确传递数组参数并避免URL编码错误?

Vue中axios GET请求:如何正确传递数组参数并避免URL编码错误?

本文探讨在vue项目中使用axios发送get请求时,如何安全有效地传递数组参数,避免url编码错误。 许多开发者在处理包含中文或特殊字符的数组参数时会遇到问题。我们将分析一个案例,并提供解决方案。

问题: 开发者试图使用axios的GET请求将前端数组this.searchRoomTags传递到后端接口/searchRoomTags。前端代码直接在params对象中传递数组,但后端使用@RequestParam String[] roomTags接收参数,导致java.lang.IllegalArgumentException: Invalid character found in the request target错误。此错误通常与GET请求的URL参数编码和服务器端参数处理有关。

前端代码(错误示例):

this.$axios    .get('/searchRoomTags', {      params: {        pageSize: this.roomPageInfo.pageSize,        roomType: encodeURI(this.roomForm.roomType),        roomTags: this.searchRoomTags,        roomState: this.searchContent      }    })    // ...

后端代码(Java Spring Boot):

@CrossOrigin@GetMapping("/searchRoomTags")@ResponseBodypublic PageInfo searchRoomTags(@RequestParam String[] roomTags, Rooms room, HttpServletRequest request) {    // ...}

错误原因: GET请求的参数通过URL传递,URL对数组的处理方式与直接传递字符串不同,直接传递数组会导致URL中出现无效字符。

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

解决方案: 将数组转换为以特定分隔符连接的字符串,再传递给后端。

修改后的前端代码:

this.$axios    .get('/searchRoomTags', {      params: {        pageSize: this.roomPageInfo.pageSize,        roomType: encodeURI(this.roomForm.roomType),        roomTags: (this.searchRoomTags || []).join(','), // 将数组转换为以逗号分隔的字符串        roomState: this.searchContent      }    })    // ...

后端代码修改: 后端需要修改接收参数的方式,例如使用@RequestParam String roomTags,然后在后端代码中使用逗号(或其他选择的分割符)将字符串分割成数组。

注意事项: 选择合适的分割符,并确保该分隔符不会出现在数组元素中。如果数组元素可能包含该分隔符,则需要选择其他分隔符或使用更复杂的编码方式,例如JSON编码。 这种方法简单易行,但对于复杂数据结构,建议使用JSON编码,更安全可靠。

以上就是Vue中axios GET请求:如何正确传递数组参数并避免URL编码错误?的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

发表回复

登录后才能评论
关注微信