在ASP.NET Core Web API中,可以通过多种方式限制文件上传的大小。本文将介绍两种验证文件上传最大尺寸的方法。
方法一:使用属性验证器 使用[MaxFileSize]属性验证器来限制文件的最大上传尺寸。该验证器可在服务器响应之前立即验证文件。以下是使用属性验证器的代码示例:
在Models文件夹中新建一个类FileUploadModel.cs:
using Microsoft.AspNetCore.Http;
using System.ComponentModel.DataAnnotations;
namespace YourNamespace.Models
{
public class FileUploadModel
{
[Required]
[MaxFileSize(50 * 1024 * 1024)] // 50 MB
public IFormFile File { get; set; }
}
}
在控制器中使用该模型验证文件上传最大值:
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using YourNamespace.Models;
namespace YourNamespace.Controllers
{
[ApiController]
[Route("api/[controller]")]
public class FileUploadController : ControllerBase
{
[HttpPost]
public IActionResult AddFile(FileUploadModel model)
{
//处理文件上传的逻辑
}
}
}
方法二:在startup.cs中添加全局过滤器 在startup.cs文件的ConfigureServices()方法中为认证添加maxRequestBodySize设置。以下是示例代码:
public void ConfigureServices(IServiceCollection services)
{
//...
//限制文件上传大小
services.Configure(options =>
{
options.MaxRequestBodySize = 52428800; //50MB
});
//...
}
上述示例代码将文件上传的最大值设置为50MB。因此,您可以根据需要自定义此值。
为确保更好的用户体验,建议在客户端上传文件前进行验证。
上一篇:ASP.NETCoreWebAPI-如何显示具有相应角色的用户
下一篇:ASP.NETCoreWebAPI-如何在ApplicationDbContext的SaveChangesAsync中实现当前用户名?