我想出了一种方法来使用 DTO 并将上传的文件指定为 FormData 中的 File 对象。这是因为我有其他需要与 File 对象一起发送的字段值。
服务器
创建具有所需属性的 DTO 对象。
public class SaveAccountRequest
{
public string AccountName { get; set; }
public IFormFile Statement { get; set; }
}
在控制器端点中添加 DTO 作为接受的参数。
[HttpPost]
public IActionResult SaveAccount([FromForm] SaveAccountRequest saveAccountRequest)
{
//you should be able to access the Statement property as an IFormFile in the saveAccountRequest.
}
客户
将所有属性附加到 FormData 对象,并确保根据服务器端 DTO 中使用的名称命名它们。
const formData = new FormData();
formData.append("accountName", accountName);
formData.append("statement", file);
将数据发布到 SaveAccount 端点。我正在使用 fetch API 来发布数据,但一个简单的帖子也应该可以工作。请确保在发送文件请求时将内容类型设置为多部分表单数据。
this.http.fetch(<api endpoint url>, { method: "POST", body: formData, content-type: 'multipart/form-data' });