ASP.NET Core 文件上传下载核心是 IFormFile 和 FileStreamResult/PhysicalFile;需校验空文件、安全重命名、目录预创建、类型检查;大文件要调优 MaxRequestBodySize 和使用流式传输。
ASP.NET Core 实现文件上传和下载非常直接,核心是利用 IFormFile 接口处理上传,用 FileStreamResult 或 PhysicalFile 返回文件。
前端用标准表单(enctype="multipart/form-data")提交,后端通过参数绑定获取 IFormFile:
IFormFile file 参数IFormFile[] files 或 IEnumerable
file.Length > 0 和 file.FileName 是否为空,避免空上传别直接用用户传来的 FileName 存盘,防止路径遍历或覆盖系统文件:
Path.GetRandomFileName() 或 Guid.NewGuid() 生成安全文件名Path.Combine(_env.WebRootPath, "uploads")),并提前创建目录file.ContentType 或读取文件头),但不能只依赖扩展名两种常用方式:
return PhysicalFile(filePath, contentType, fileName)
return File(fileBytes, contentType, fileName)
FileStreamResult 流式传输,避免全量加载到内存默认 ASP.NET Core 限制请求体最大为 128 MB,超限会直接 404 或 413:
Program.cs 中调用 ConfigureKestrel 设置 MaxRequestBodySize
[RequestSizeLimit(100_000_000)](单位字节)
在 web.config 中设置 maxAllowedContentLength
基本上就这些。不复杂但容易忽略安全校验和配置调优。