本文共 635 字,大约阅读时间需要 2 分钟。
众所周知,前端要发送文件给后端接口,用的方法就是axios + new formData()
前端:
var data = new FormData(); data.append("account", this.formData.account); console.log("img type:" + typeof this.img); data.append("img", this.img); axios.post(url, data).then(function (response) { });
后端:
@PostMapping("/add") public Result add(User user, MultipartFile img){ return null; }
后端接口看起来毛得问题对吧?但就是一直400,我!!!!
然后我反复用Swagger测试接口,后面我突然意识到 User 实体类中有一个 String img 字段!
果然没错!就是这个String img 和 接口的文件 img 重名了!
因为前端传来的字段会根据字段名匹配实体类的属性,所以会出现文件转换字符串失败的操作!
都是因为自己起名字的问题,可见,起名字是个很讲究的学问啊!
能排查出问题也多亏有专门测试后端接口的工具,不用老是要通过前端点击来测试了,可见,测试接口 的便捷性和重要性!
转载地址:http://udern.baihongyu.com/