測(cè)試環(huán)境:
后端:nodejs express + multer
前端:axios
文本和文件混合上傳時(shí),multer拿不到文本值衰伯,而在router中卻可以得到body的值铡羡,經(jīng)過測(cè)試,在formdata中 append有順序問題意鲸,必須先傳文本數(shù)據(jù)烦周,再傳文件,否則在multer的自定義攔截中無法拿到req.body的文本值怎顾。
測(cè)試代碼:
const fileChange = (e) => {
// 必須保證先傳遞文本數(shù)據(jù)读慎,再穿文件數(shù)據(jù)
formData.append('type', 'test')
formData.append('file', e.currentTarget.files[0]) // 通過input拿到文件
axios.post('http://localhost:8080/upload', formData)
}
后臺(tái):
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