在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作

简介: 【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
  1. 操作筛选器简介
  • 操作筛选器是ASP.NET Core MVC(Model - View - Controller)和 Web API 中的一种过滤器类型。它可以在操作方法(也就是 API 中的控制器方法)执行之前和之后运行代码。这对于实现诸如日志记录、性能监控、验证等横切关注点非常有用。操作筛选器实现了IActionFilter接口,该接口包含两个方法:OnActionExecuting(在操作方法执行之前调用)和OnActionExecuted(在操作方法执行之后调用)。
  1. 创建操作筛选器类
  • 首先,创建一个类来实现操作筛选器。例如,创建一个名为CustomActionFilter的类,它实现IActionFilter接口。


using Microsoft.AspNetCore.Mvc.Filters;
   using Microsoft.Extensions.Logging;
   public class CustomActionFilter : IActionFilter
   {
       private readonly ILogger<CustomActionFilter> _logger;
       public CustomActionFilter(ILogger<CustomActionFilter> logger)
       {
           _logger = logger;
       }
       public void OnActionExecuting(ActionExecutingContext context)
       {
           // 在操作方法执行之前记录日志
           _logger.LogInformation("操作方法即将执行");
           // 可以在这里进行验证等操作,例如检查模型状态
           if (!context.ModelState.IsValid)
           {
               context.Result = new BadRequestObjectResult(context.ModelState);
           }
       }
       public void OnActionExecuted(ActionExecutedContext context)
       {
           // 在操作方法执行之后记录日志
           _logger.LogInformation("操作方法已经执行");
           // 可以在这里处理异常等情况
           if (context.Exception!= null)
           {
               _logger.LogError(context.Exception, "操作方法执行出错");
               context.ExceptionHandled = true;
               context.Result = new ObjectResult("操作出错")
               {
                   StatusCode = 500
               };
           }
       }
   }


  • 在上述代码中:
  • 构造函数注入了ILogger用于记录日志。
  • OnActionExecuting方法在操作方法执行前被调用。这里检查了模型状态是否有效,如果无效,直接返回BadRequestObjectResult,避免执行无效的操作方法。
  • OnActionExecuted方法在操作方法执行后被调用。如果操作过程中出现异常,记录异常日志,设置ExceptionHandledtrue表示异常已经被处理,然后返回一个包含错误信息的ObjectResult,状态码设置为500


  1. 注册操作筛选器
  • 要使操作筛选器生效,需要在Startup.cs文件的ConfigureServices方法中注册它。


public void ConfigureServices(IServiceCollection services)
   {
       services.AddControllers(options =>
       {
           options.Filters.Add<CustomActionFilter>();
       });
       // 其他服务注册代码...
   }


  • 通过options.Filters.Add<CustomActionFilter>();CustomActionFilter添加到过滤器集合中。这样,在每个操作方法执行前后,都会执行CustomActionFilter中的相应逻辑。


通过以上步骤,就可以在ASP.NET Core Web API 中使用操作筛选器来统一处理通用操作,如日志记录、验证和异常处理等。这种方式提高了代码的可维护性和复用性,避免了在每个操作方法中重复编写相同的逻辑。

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
6月前
|
开发框架 .NET C#
ASP.NET Core Blazor 路由配置和导航
大家好,我是码农刚子。本文系统介绍Blazor单页应用的路由机制,涵盖基础配置、路由参数、编程式导航及高级功能。通过@page指令定义路由,支持参数约束、可选参数与通配符捕获,结合NavigationManager实现页面跳转与参数传递,并演示用户管理、产品展示等典型场景,全面掌握Blazor路由从入门到实战的完整方案。
538 6
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
527 5
|
开发框架 前端开发 JavaScript
ASP.NET Web Pages - 教程
ASP.NET Web Pages 是一种用于创建动态网页的开发模式,采用HTML、CSS、JavaScript 和服务器脚本。本教程聚焦于Web Pages,介绍如何使用Razor语法结合服务器端代码与前端技术,以及利用WebMatrix工具进行开发。适合初学者入门ASP.NET。
|
开发框架 .NET 程序员
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
Autofac 是一个轻量级的依赖注入框架,专门为 .NET 应用程序量身定做,它就像是你代码中的 "魔法师",用它来管理对象的生命周期,让你的代码更加模块化、易于测试和维护
648 4
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
411 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
开发框架 算法 中间件
ASP.NET Core 中的速率限制中间件
在ASP.NET Core中,速率限制中间件用于控制客户端请求速率,防止服务器过载并提高安全性。通过`AddRateLimiter`注册服务,并配置不同策略如固定窗口、滑动窗口、令牌桶和并发限制。这些策略可在全局、控制器或动作级别应用,支持自定义响应处理。使用中间件`UseRateLimiter`启用限流功能,并可通过属性禁用特定控制器或动作的限流。这有助于有效保护API免受滥用和过载。 欢迎关注我的公众号:Net分享 (239字符)
372 1
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
435 3
|
开发框架 .NET PHP
ASP.NET Web Pages - 添加 Razor 代码
ASP.NET Web Pages 使用 Razor 标记添加服务器端代码,支持 C# 和 Visual Basic。Razor 语法简洁易学,类似于 ASP 和 PHP。例如,在网页中加入 `@DateTime.Now` 可以实时显示当前时间。
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
673 0
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
353 7