【发布时间】:2021-11-04 10:48:19
【问题描述】:
vanilla javascript 客户端(我尝试使用 axios/ajax/fetch)
const myForm = document.getElementById("myForm");
myForm.addEventListener("submit", (e) => {
debugger;
var name = document.getElementById("errorInput").value;
var description = document.getElementById("errorDescriptionInput").value;
var date = document.getElementById("errorDateInput").value;
var mail = document.getElementById("senderEmailInput").value;
var file = document.getElementById('fileInput').files[0];
var formData = new FormData();
formData.append('fileInput', file);
const error = {
ErrorName: name,
ErrorDescription: description,
ErrorSubmittedDate: date,
SenderEmail: mail,
Documents: formData,
}
axios.post("https://localhost:44310/api/Error/senderror","sendFile", error, {
"Content-Type": "multipart/form-data",
"Content-Type": "application/json",
})
})
.net 控制器 API
[EnableCors("policy")]
[HttpPost]
[Route("senderror")]
public async Task<IActionResult> HandleError([FromForm]ErrorModel error)
{
return Ok();
}
浏览器调试器显示模型包含值,但到达控制器的数据为空。 感谢大家的帮助!
【问题讨论】:
-
我认为问题出在内容类型上,您不能拥有具有“multipart/form-data”或“application/json”两个值的相同属性。您应该尝试删除“Content-Type”:“application/json”。
标签: javascript c# .net api axios