.Net Core自定义异常过滤器

当系统中出现未经处理的异常时,异常过滤器就会执行。

下面以WebApi项目为例,记录异常过滤器的使用方法。

需求:当开发环境出现异常时,返回异常的堆栈信息。非开发环境出现异常,返回字符串“服务器发生未处理异常”。

1.新建一个WebApi项目,创建一个控制器类,写一个测试action,访问一个不存在的文件。

using Microsoft.AspNetCore.Mvc;

namespace WebApiFilter.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class DemoController : ControllerBase
    {
        [HttpGet]
        public string Test1()
        {
            string s = System.IO.File.ReadAllText("f:/1.txt");
            return s;
        }
    }
}

 

2.自定义类MyExceptionFilter,实现接口IAsyncExceptionFilter。

using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;
using System.Threading.Tasks;

namespace WebApiFilter
{
    public class MyExceptionFilter : IAsyncExceptionFilter
    {
        private readonly IWebHostEnvironment _environment;
        public MyExceptionFilter(IWebHostEnvironment environment)
        {
            this._environment = environment;
        }


        public Task OnExceptionAsync(ExceptionContext context)
        {
            //context.Exception代表异常信息对象
            //如果给 context.ExceptionHandled赋值为true,则其他ExceptionFilter不会被执行
            //context.Result的值会被输出到客户端

            string msg;
            if (_environment.EnvironmentName == "Development")
            {
                msg = context.Exception.ToString();
            }
            else
            {
                msg = "服务器发生未处理异常";
            }

            ObjectResult objectResult = new ObjectResult(new
            {
                code = 500,
                message = msg
            });
            context.Result = objectResult;//context.Result的值会被输出到客户端
            context.ExceptionHandled = true;//其他ExceptionFilter不会被执行
            return Task.CompletedTask;
        }
    }
}

3.将自定义的异常过滤器进行注入。

 

设置运行环境变量值为开发,运行项目,可以看到输出的异常信息。

 

 

设置运行环境变量值为其他,运行项目,可以看到输出的异常信息。

 

到此为止,已经实现了根据环境变量的值输出不同的错误信息。

同时可以执行多个自定义的异常过滤器,例如,在上面的基础上,增加异常日志记录的过滤器,发生未经处理的异常时,将异常信息记录到日志文件中。

创建LogExceptionFilter过滤器类,实现IAsyncExceptionFilter接口。

using Microsoft.AspNetCore.Mvc.Filters;
using System.IO;
using System.Threading.Tasks;

namespace WebApiFilter
{
    public class LogExceptionFilter : IAsyncExceptionFilter
    {
        public Task OnExceptionAsync(ExceptionContext context)
        {
            //将异常信息记录到日志文件中
            return File.AppendAllTextAsync("f:/error.log", context.Exception.ToString());
        }
    }
}

将新加的过滤器注入到服务中

 

运行项目,就会看到异常信息被记录到文件中了。

 日志文件的内容:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值