.NET Core中异常过滤器ExceptionFilter的使用介绍

介绍

实现需要继承IExceptionFilter 或 IAsyncExceptionFilter。

可用于实现常见的错误处理策略。

使用场景

首先讲一下我们为什么要使用异常过滤器 ,如果业务场景复杂,只使用HttpStatusCode,抛出异常后,后期要加很多字段来描述。

那么这种就比较不适合, 我们就可以自己定义一套规则, 比如返回结果必须是 code, data, Message等那我们就要写一个通用数据model。

    public class ApiResult<T>    {        public int Code { get; set; }        public string Message { get; set; }        public T Data { get; set; }    }

定义一套自己的code标准, 比如1 成功,0 系统异常, 1xx 某类业务, 2xx 某类业务 。

所以我们在抛出异常的时候需要去处理 ,所以异常过滤器就派上用场了,当然还可以用中间件处理异常,这里就不说了!

使用

  新建ExceptionFilter 继承IAsyncExceptionFilter

    若要处理异常,将 属性 ExceptionHandled 设置为 或 true 分配 Result 属性。

    这将停止传播异常。异常筛选器无法将异常转变为“成功”。只有操作筛选器才能执行该转变。

在处理异常的时候获取到context.Exception就能处理不同的异常类型了!

我这里自定义了一个异常类, 当然实际场景中根据业务来新建你们自己的异常类满足需求就行了了!

​​​​​​​

  public class ServicesException : Exception    {        public override string Message { get; }        public ServicesException(string message) : base(message)        {            this.Message = message;        }    }

ExceptionFilter 类:

​​​​​​​

 public class ExceptionFilter : IAsyncExceptionFilter    {          public Task OnExceptionAsync(ExceptionContext context)        {            // 如果异常没有被处理则进行处理            if (context.ExceptionHandled == false)            {                int code = 0;                if (context.Exception is ServicesException)                {                    code = 1;                }

                // 定义返回类型                var result = new ApiResult<string>                {                    Code = code,                    Message = context.Exception.Message,                    Data=""                };                context.Result = new ContentResult                {                    // 返回状态码设置为200,表示成功                    StatusCode =(int)HttpStatusCode.OK,                    // 设置返回格式                    ContentType = "application/json;charset=utf-8",                    Content = JsonConvert.SerializeObject(result)                };            }            // 设置为true,表示异常已经被处理了            context.ExceptionHandled = true;            return Task.CompletedTask;        }    }

最后我们将异常过滤器注册到全局即可!(局部注册可参看)

.NET Core中行为过滤器ActionFilterAttribute的使用介绍

黑哥聊dotNet,公众号:黑哥聊dotNet.NET Core中行为过滤器ActionFilterAttribute的使用介绍

services.AddControllers(o => o.Filters.Add(typeof(ExceptionFilter)));

测试代码与结果:

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在ASP.NET Core,可以通过编写过滤器来实现在请求处理过程插入自定义逻辑。下面是编写过滤器的步骤: 1. 创建一个过滤器类:可以创建一个继承自`IFilterMetadata`接口的类,或者继承自`Attribute`类的特性类,来定义过滤器的逻辑。 2. 实现过滤器逻辑:在过滤器,可以实现以下方法来定义过滤器的逻辑: - OnActionExecuting:在执行控制器动作方法之前调用。 - OnActionExecuted:在执行控制器动作方法之后调用。 - OnResultExecuting:在执行结果之前调用。 - OnResultExecuted:在执行结果之后调用。 这些方法可以根据需要选择实现,以执行相应的逻辑。 3. 注册过滤器:可以通过在Startup.cs文件的`ConfigureServices`方法使用`services.AddMvc(options => options.Filters.Add<CustomFilter>())`来注册过滤器。也可以使用特性标记在控制器或动作方法上直接应用过滤器。 4. 应用过滤器过滤器可以应用于整个应用程序、控制器或单个动作方法。通过在Startup.cs文件的`Configure`方法使用`app.UseMvc()`来应用过滤器。 这样,当请求到达应用程序时,过滤器的逻辑会按照定义的顺序被执行,并可以在请求处理过程插入自定义的逻辑。过滤器可以用于实现身份验证、日志记录、异常处理等功能。 需要注意的是,过滤器的执行顺序是按照注册的顺序来决定的,可以通过在注册过滤器时设置优先级来控制执行顺序。另外,过滤器还可以通过依赖注入来获取其他服务和组件,以便进行更复杂的逻辑处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值