Angular端代码:
uploadFiles(files: File[]) {
const formData = new FormData();
for(let i = 0; i < files.length; i++) {
formData.append('files', files[i]);
}
const headers = new HttpHeaders({
'Authorization': 'Bearer ' + this.token,
'enctype': 'multipart/form-data'
});
const options = { headers: headers };
return this.http.post(this.apiUrl + 'upload', formData, options);
}
ASP.NET Core API端代码:
[HttpPost("upload")]
public async Task Upload(IFormCollection file)
{
var files = HttpContext.Request.Form.Files;
long size = files.Sum(f => f.Length);
foreach (var formFile in files)
{
if (formFile.Length > 0)
{
var filePath = Path.GetTempFileName();
using (var stream = new FileStream(filePath, FileMode.Create))
{
await formFile.CopyToAsync(stream);
}
}
}
return Ok(new { count = files.Count, size });
}
其中,我们使用了"HttpContext.Request.Form.Files"来获取上传的文件集合。 如果没有正确设置请求头,则可能会收到"empty"文件。