【发布时间】:2021-02-26 22:17:10
【问题描述】:
我正在运行 Angular 9 应用程序,我想实现文件上传行为。在表单中,用户必须输入标题、描述并仅上传一个 .zip 格式的文件,在单击提交时,我想通过以下方式将表单值与文件一起发送到后端(使用 dotnet) http post 调用。
file-upload.component.ts
uploadFile(files) {
const formData = new FormData();
const fileToUpload = files[0] as File;
formData.append('file', fileToUpload, fileToUpload.name);
const data = {
title: this.form.value.Title,
description: this.form.value.Description,
File: formData
};
console.log(data);
this.http.post('https://localhost:5001/api/idea/add', data).subscribe((response) => {
console.log(response);
}});
}
file-upload.component.html
<input type="file" #file placeholder="Choose file" (change)="uploadFile(file.files)" multiple>
FileController.cs
[HttpPost("api/idea/add")]
public async Task<IActionResult> AddIdea([FromBody] IdeaDto ideaDto) { }
后端期望数据采用以下格式
IdeaDto.cs
public class IdeaDto
{
public IFormFile File { get; set; }
public string Title { get; set; }
public string Description { get; set; }
}
我在提交数据时遇到错误
另外,我做了 console.log(data) 并获得了 File 值,如下图所示。我不确定这是否是正确的数据
这里有什么问题?我真的没有想法,也许在花了这么多时间后我需要重新思考一下
【问题讨论】:
标签: javascript c# angular typescript .net-core