1.创建一个文件上传的表单
在一个视图中(比如Index.cshtml
),添加一个表单来让用户选择文件并上传。
@model IFormFile
<form method="post" enctype="multipart/form-data">
<div class="form-group">
<label for="file">选择文件</label>
<input type="file" class="form-control-file" id="file" name="file">
</div>
<button type="submit" class="btn btn-primary">上传</button>
</form>
注意enctype="multipart/form-data"
属性是必须的,因为它告诉浏览器以多部分表单数据的形式发送数据,这对于文件上传是必需的。
2. 控制器中处理文件上传
在控制器中,需要一个动作方法来处理文件上传。以下是一个简单的例子:
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using System.IO;
public class HomeController : Controller
{
public IActionResult Index()
{
return View();
}
[HttpPost]
public IActionResult UploadFile(IFormFile file)
{
if (file == null || file.Length == 0)
{
return Content("请选择一个文件上传。");
}
var filePath = Path.Combine(Directory.GetCurrentDirectory(), "wwwroot", "uploads", file.FileName);
// 确保上传的文件夹存在
var fileInfo = new FileInfo(filePath);
fileInfo.Directory.Create();
// 保存文件
using (var stream = new FileStream(filePath, FileMode.Create))
{
file.CopyTo(stream);
}
return Content($"文件 '{file.FileName}' 上传成功!");
}
}
注意事项
- 在实际应用中,你可能需要添加额外的验证来确保上传的文件类型、大小等符合你的要求。
- 示例中直接将文件保存在
wwwroot/uploads
目录下,你可能需要根据实际情况调整路径。 - 对于大文件上传,你可能需要考虑实现文件分块上传或使用第三方库来处理。
- 出于安全考虑,确保不要将上传的文件保存在Web应用的根目录下,以免用户直接通过URL访问到这些文件。
- 示例代码中的文件保存逻辑非常简单,没有进行错误处理。在实际应用中,你应该添加适当的错误处理逻辑来增强程序的健壮性。