新闻中心
C# 如何在 ASP.NET Core 中上传文件_C# ASP.NET Core 文件上传实现指南
答案:ASP.NET Core通过IFormFile实现文件上传,支持单多文件、大文件限制及安全验证。使用IFormFile接收文件,配置FormOptions调整大小限制,结合RequestSizeLimit特性,前端表单需设multipart/form-data编码,建议验证扩展名、MIME类型并重命名文件以保障安全。

在 ASP.NET Core 中实现文件上传是一个常见需求,比如用户上传头像、文档或附件。实现方式简单高效,同时支持单文件和多文件上传,并能有效处理大文件和安全限制。
启用文件上传的控制器配置
ASP.NET Core 使用 IFormFile 接口来表示通过 HTTP 请求上传的文件。你需要在控制器中创建一个接收该类型的参数的方法。
确保控制器允许表单数据提交:
[HttpPost("upload")]
public async Task<IActionResult> UploadFile(IFormFile file)
{
if (file == null || file.Length == 0)
return BadRequest("No file uploaded.");
var filePath = Path.Combine(Directory.GetCurrentDirectory(), "uploads", file.FileName);
using (var stream = new FileStream(filePath, FileMode.Create))
{
await file.CopyToAsync(stream);
}
return Ok($"File {file.FileName} uploaded successfully.");
}
注意:确保目标目录(如 uploads)存在,否则会抛出异常。
支持多文件上传
如果需要一次上传多个文件,可以将参数改为 IFormFileCollection 或 IEnumerable
[HttpPost("upload-multiple")]
public async Task<IActionResult> UploadMultipleFiles(IEnumerable<IFormFile> files)
{
foreach (var file in files)
{
if (file.Length > 0)
{
var filePath = Path.Combine("uploads", file.FileName);
using (var stream = new FileStream(filePath, FileMode.Create))
{
await file.CopyToAsync(stream);
}
}
}
return Ok($"{files.Count()} files uploaded.");
}
前端 HTML 表单示例
上传页面需要使用 multipart/form-data 编码类型:
<form method="post" enctype="multipart/form-data" action="/upload"> <input type="file" name="file" /> <button type="submit">Upload</button> </form>
对于多文件上传,添加 multiple 属性:
Pippit AI
CapCut推出的AI创意内容生成工具
133
查看详情
<input type="file" name="files" multiple />
配置文件大小和请求限制
默认情况下,ASP.NET Core 限制请求体大小(通常为 30MB),大文件上传需调整设置。
在 Program.cs 中配置:
builder.Services.Configure<FormOptions>(options =>
{
options.MultipartBodyLengthLimit = 52428800; // 50 MB
});
也可使用 RequestSizeLimit 特性控制特定 Action:
[RequestSizeLimit(100_000_000)] // 100 MB
[HttpPost("upload-large")]
public async Task<IActionResult> UploadLargeFile(IFormFile file)
{
// 处理逻辑
}
安全与验证建议
直接保存上传文件存在风险,应加入以下检查:
- 验证文件扩展名,避免可执行文件(.exe, .bat, .asp 等)
- 检查 MIME 类型是否匹配
- 重命名上传文件,防止路径遍历攻击
- 限制文件大小
- 扫描病毒(生产环境建议集成防病毒服务)
示例:检查扩展名
var allowedExtensions = new[] { ".jpg", ".png", ".pdf" };
var ext = Path.GetExtension(file.FileName).ToLowerInvariant();
if (!allowedExtensions.Contains(ext))
return BadRequest("Invalid file type.");
基本上就这些。ASP.NET Core 的文件上传机制灵活且易于扩展,结合中间件还可实现进度反馈、分片上传等功能。关键是做好输入验证和资源管理,避免安全隐患。
以上就是C# 如何在 ASP.NET Core 中上传文件_C# ASP.NET Core 文件上传实现指南的详细内容,更多请关注其它相关文章!
# 前端
# 如何在
# 文档
# 大文件
# 扩展名
# 表单
# 如何实现
# 上传文件
# 上传
# .net
# c#
# 配置文件
# stream
# pdf
# ai
# 编码
# html
# 文件上传
# 免费优化网站文件
# 南京网站建设答疑解惑
# seo 常用浏览器插件
# 银川网站建设方案表
# 白山抖音关键词排名方法
# 明星搜索网站建设
# 英语培训网站建设
# 自动网站建设系统cms
# 南山全网推广营销平台
# 上林全网营销推广
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
Excel如何用迷你图显趋势_Excel用迷你图显趋势【趋势小图】
J*a应用程序首次运行自动创建文件与目录的最佳实践
J*aScript:在map操作中高效处理空数组
微博网页版直接访问 微博网页版账号管理快速入口
TypeScript/J*aScript:高效查找数组中首个唯一ID对象
Win11怎么合并任务栏图标 Win11开启任务栏合并减少图标占空间【方法】
怎样使用“本地安全策略”提升Windows安全性_Secpol.msc配置指南【高手】
CSS布局:解决全屏元素100%尺寸与外边距导致的页面溢出问题
动漫花园资源网使用步骤_动漫花园资源网下载流程
Win10系统服务哪些可以禁用 Win10安全优化服务列表【干货】
sublime怎么设置启动时打开的窗口_sublime会话管理与热退出
漫蛙2漫画入口 漫蛙正版网页漫画直达网址
如何使用纯J*aScript判断Input元素是否在特定类容器内
Safari浏览器输入栏卡顿如何解决 Safari搜索建议与缓存清理
Yandex搜索引擎一键访问入口_俄罗斯Yandex官网免登录
Win10如何清理注册表垃圾 Win10手动清理无效注册表【技巧】
Golang如何使用context实现超时取消_Golang context超时取消模式实践
必由学网页版入口 必由学官方平台直接访问
Tailwind CSS line-clamp 布局问题解析与修复指南
“音游” × “怪文书” 题材的节奏冒险游戏 《晕晕电波症候群》确定于2026年4月发售!
MinIO大规模对象列表性能瓶颈深度解析与外部元数据管理策略
Safari自带网页翻译功能怎么用 无需插件轻松看懂外文网站【方法】
Angular Material 垂直步进器:实现底部到顶部排序的教程
J*a里如何使用forEach遍历Map_Map遍历方法说明
初次安装JDK时环境变量如何正确配置_J*A_HOME与PATH设置规则讲解
Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】
CSS响应式网页如何实现主次模块比例自适应_flex-grow与flex-shrink调整
在Go开发中优雅管理ListenAndServe进程:GoSublime集成方案
KFC游戏互动怎么赢取优惠券_KFC线上游戏活动参与与优惠代码赢取教程
在J*a中如何开发在线活动报名与管理系统_活动报名管理项目实战解析
支付宝解绑银行卡步骤_支付宝如何解除绑定银行卡
微博网页版主页入口 微博官方网站免登录访问
mysql通配符支持数字匹配吗_mysql通配符能否用于数字匹配的解析
Django模型中自动计算可用余额的实现方法
Windows10怎么开启存储感知 Windows10系统设置自动清理临时文件释放C盘空间【教程】
优化大型XML文件解析:基于Python流式处理的内存高效方案
蓝湖怎样用切图标注提对接效率_蓝湖用切图标注提对接效率【设计对接】
Golang如何使用const iota_Go iota常量计数器讲解
深入理解字体排版:Adobe光学字偶距与CSS字偶距的差异与实现
Lar*el 8 多关键词数据库搜索优化实践
漫蛙2网页版漫画入口 漫蛙漫画在线官方登录
手机屏幕碎了但能正常使用怎么办 手机外屏碎裂的修复建议
深入理解Promise链:如何在catch后中断then的执行
顺丰国际快递查询 国际件官方查询入口
腾讯QQ邮箱登录入口_QQ邮箱官方网站使用地址
b站怎么看视频的弹幕数量_b站弹幕数量查看方法
J*aScript DOM操作:高效清空列表元素的策略与实践
在python-socketio事件处理器中安全访问Flask应用上下文
QQ邮箱网页版入口 QQ邮箱官方邮箱登录通道
快手网页版在线登录 快手网页版官网入口快速访问


2025-11-03
浏览次数:次
返回列表
quot; action="/upload">
<input type="file" name="file" />
<button type="submit">Upload</button>
</form>