测试环境:
后端:nodejs express + multer
前端:axios
文本和文件混合上传时,multer拿不到文本值,而在router中却可以得到body的值,经过测试,在formdata中 append有顺序问题,必须先传文本数据,再传文件,否则在multer的自定义拦截中无法拿到req.body的文本值。
测试代码:
const fileChange = (e) => {
// 必须保证先传递文本数据,再穿文件数据
formData.append('type', 'test')
formData.append('file', e.currentTarget.files[0]) // 通过input拿到文件
axios.post('http://localhost:8080/upload', formData)
}
后台:
const storage = multer.diskStorage({
destination: function (req, file, cb) {
console.log( req.body, file);
cb(null, 'D:/')
},
filename: function (req, file, cb) {
cb(null, file.originalname)
}
})
image.png