我有一個節點 js 后端,需要將檔案發送到 Spring Boot 應用程式。
該檔案是本地上傳/testsheet.xlsx。
這是使用 form-data npm 模塊和 Axios 上傳檔案的代碼。
const formData = new FormData()
formData.append("file", fs.createReadStream("uploads/testsheet.xlsx"));
formData.append("status", status);
const path = `/endpoint`
const auth = {
username: username,
password: password
}
const url = `${baseUrl}${path}`
const response = await sendRequest(url, auth, "POST", formData, null, null, null)
//sendRequest Code -
try {
const response = await axios({
method,
url,
data,
params,
headers,
auth,
config,
})
return response
} catch (err) {
console.log(`Fetch Error: => ${method}:${url} => ${err.message || err.response}`)
return err.response ? { error: err.response.data.message } : { error: err.message }
}
Spring boot 端有以下代碼 -
@PostMapping("/endpoint")
public StatusResponse update(@RequestParam("file") MultipartFile file, @RequestParam("status") String status){
boolean response = transactionService.update(file, status);
return statusResponse;
}
在春季啟動方面,我不斷收到此錯誤-
org.springframework.web.multipart.MultipartException: Current request is not a multipart request
從郵遞員發送時,一切正常。!!!
如何成功發送多部分檔案?
uj5u.com熱心網友回復:
您應該使用物件提供的.getHeaders()功能,formData以便正確設定多部分表單邊界,例如:
const res = await axios.post(url, formData, {
headers: formData.getHeaders()
});
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/480283.html
