当前位置: 首页 > ds >正文

Asp.Net Core 异常筛选器ExceptionFilter

文章目录

  • 前言
  • 一、异常筛选器的核心概念
    • 用途:
    • 实现接口:
    • 执行时机:
  • 二、使用步骤
    • 1.创建自定义异常筛选器
    • 2.注册异常筛选器
      • 全局注册(对所有 Controller 生效):
      • 局部注册(通过特性标记特定的 **Controller** 或 **Action**):
  • 三、异常筛选器与中间件异常处理的区别
  • 四、高级用法
  • 五、注意事项
  • 总结


前言

在 ASP.NET Core 中,异常筛选器(Exception Filters) 是 MVC 框架提供的一种机制,用于集中处理控制器(Controller)或 Action 方法中抛出的异常。它们允许你在异常发生时拦截并自定义处理逻辑,例如记录日志、返回特定格式的错误响应或执行恢复操作。


一、异常筛选器的核心概念

用途:

  1. 统一异常处理逻辑,避免重复的 try-catch 块。
  2. 根据异常类型返回不同的 HTTP 响应。
  3. 记录异常日志或触发监控告警。

实现接口:

  1. 同步筛选器:IExceptionFilter
  2. 异步筛选器:IAsyncExceptionFilter

执行时机:

  1. 控制器Action 方法抛出未处理的异常时触发。
  2. 不处理中间件或路由之外的异常(如身份验证中间件的异常需通过中间件处理)。

二、使用步骤

1.创建自定义异常筛选器

  1. 通过实现 IExceptionFilterIAsyncExceptionFilter 接口创建自定义筛选器::
    public class MyExceptionFilter : IAsyncExceptionFilter
    {private readonly IWebHostEnvironment hostEnv;public MyExceptionFilter(IWebHostEnvironment hostEnv){this.hostEnv = hostEnv;}public Task OnExceptionAsync(ExceptionContext context){string msg;if (hostEnv.IsDevelopment()){msg=context.Exception.ToString();}else{msg = "服务器端发生异常未处理。";}ObjectResult objectResult = new ObjectResult(new{Code = 500,Message = msg}){StatusCode = StatusCodes.Status500InternalServerError};//ObjectResult objectResult = new ObjectResult(new ProblemDetails//{//    Title = "服务器异常",//    Status = StatusCodes.Status500InternalServerError,//    Detail = msg//});context.Result = objectResult;context.ExceptionHandled = true;return Task.FromResult(objectResult);//return Task.CompletedTask;}
    }
    

2.注册异常筛选器

全局注册(对所有 Controller 生效):

  1. 在 Program.cs 中全局注册:
    //方式一:
    //builder.Services.AddControllers(opt =>
    //{
    //    opt.Filters.Add<MyExceptionFilter>();
    //    opt.Filters.Add<MyLogExceptionFilter>();
    //});
    //方式二:
    builder.Services.Configure<MvcOptions>(opt => {opt.Filters.Add<MyExceptionFilter>();opt.Filters.Add<MyLogExceptionFilter>();
    });
    

局部注册(通过特性标记特定的 ControllerAction):

  1. 在控制器或 Action 上使用 [TypeFilter] 或 [ServiceFilter]:
    [TypeFilter(typeof(MyExceptionFilter))]
    public class HomeController : Controller
    {// Action 方法
    }
    

三、异常筛选器与中间件异常处理的区别

特性异常筛选器中间件异常处理
作用范围仅处理 MVC 管道中的异常(控制器/Action)处理整个请求管道中的异常
上下文信息可访问 MVC 上下文(如 ActionContext)仅能访问 HttpContext
响应格式控制可返回 IActionResult(如 JSON/视图)需手动设置响应内容和类型
适用场景针对特定控制器或 Action 的精细化处理全局异常处理(如未捕获的中间件异常)

四、高级用法

  1. 处理特定异常类型:
    context.Result = new BadRequestObjectResult("Business rule violation.");
    
  2. 结合ProblemDetails(RFC 7807):
    context.Result = new ObjectResult(new ProblemDetails
    {Title = "Server Error",Status = StatusCodes.Status500InternalServerError,Detail = context.Exception.Message
    });

五、注意事项

  • 异常处理顺序:多个筛选器按注册顺序执行,可通过 Order 属性调整优先级。
  • 未处理的异常:若筛选器未标记 ExceptionHandled = true,异常会继续传播到中间件。
  • 性能:避免在筛选器中执行耗时操作(如数据库写入),建议异步处理。

总结

  • 通过合理使用异常筛选器,可以显著提升 ASP.NET Core 应用的健壮性和错误响应一致性。
  • 对于全局异常处理,建议结合中间件:
    UseExceptionHandlerapp.UseExceptionHandler(“/error”); (全局中间件)实现 更全面的覆盖。
http://www.xdnf.cn/news/2069.html

相关文章:

  • Python教程(一)——Python速览
  • 白鲸开源与亚马逊云科技携手推动AI-Ready数据架构创新
  • <论文>(谷歌)用于时序链接预测的迁移学习
  • Asp.Net Core 基于(asp.net core 2.2) 创建asp .net core空项目
  • vite+vue2+elementui构建之 package.json
  • 深度解析:从12306看混合云架构下的高并发系统设计
  • Z-Wave正通过自我革新,重塑在智能家居领域新定位
  • 2025年的营销趋势-矩阵IP
  • (Go Gin)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
  • 数据湖DataLake和传统数据仓库Datawarehouse的主要区别是什么?优缺点是什么?
  • FlinkSql入门与实践
  • Linux文件管理完全指南:从命名规则到压缩解压
  • OpenHarmony - 小型系统内核(LiteOS-A)(十),魔法键使用方法,用户态异常信息说明
  • 字节:视频一致性生成论文速读
  • 【滑动窗口+哈希表/数组记录】Leetcode 76. 最小覆盖子串
  • kafka整合flume与DStream转换
  • Linux软硬链接和动静态库(20)
  • mac brew 无法找到php7.2 如何安装php7.2
  • 【机器学习速记】面试重点/期末考试
  • 【音视频】⾳频处理基本概念及⾳频重采样
  • 企业级智能合同管理解决方案升级报告:道本科技携手DeepSeek打造智能合同管理新标杆
  • (六)机器学习---聚类与K-means
  • 基于AI应用创业IDEA:使用百度搜索开放平台的MCP广场智能推荐MCPServices服务
  • Java 安全:如何防止 DDoS 攻击?
  • 全栈国产化信创适配,构建安全可控的呼叫中心系统
  • uniapp-商城-37-shop 购物车 选好了 进行订单确认3 支付栏
  • 【vue】 实现浏览器自动播放音频的指南
  • MongoDB Shard Cluster
  • MySQL触法器
  • Cadence学习笔记之---原理图设计基本操作