asp.net core MVC 过滤器之ExceptionFilter过滤器(一)

简介

异常过滤器,顾名思义,就是当程序发生异常时所使用的过滤器。用于在系统出现未捕获异常时的处理。

实现一个自定义异常过滤器

自定义一个异常过滤器需要实现IExceptionFilter接口

public class HttpGlobalExceptionFilter : IExceptionFilter

    {

        public void OnException(ExceptionContext context)

        {

            throw new NotImplementedException();

        }

    }

IExceptionFilter接口会要求实现OnException方法,当系统发生未捕获异常时就会触发这个方法。OnException方法有一个ExceptionContext异常上下文,其中包含了具体的异常信息,HttpContext及mvc路由信息。系统一旦出现未捕获异常后,比较常见的做法就是使用日志工具,将异常的详细信息记录下来,方便修正调试。下面是日志记录的实现。

/// <summary>

    /// 全局异常过滤器

    /// </summary>

    public class HttpGlobalExceptionFilter : IExceptionFilter

    {

        readonly ILoggerFactory _loggerFactory;

        readonly IHostingEnvironment _env;


        public HttpGlobalExceptionFilter(ILoggerFactory loggerFactory, IHostingEnvironment env)

        {

            _loggerFactory = loggerFactory;

            _env = env;

        }


        public void OnException(ExceptionContext context)

        {

            var logger = _loggerFactory.CreateLogger(context.Exception.TargetSite.ReflectedType);


                logger.LogError(new EventId(context.Exception.HResult),

                context.Exception,

                context.Exception.Message);


                var json = new ErrorResponse("未知错误,请重试");


                if (_env.IsDevelopment()) json.DeveloperMessage = context.Exception;


                context.Result = new ApplicationErrorResult(json);

                context.HttpContext.Response.StatusCode = (int)HttpStatusCode.InternalServerError;


            context.ExceptionHandled = true;

        }


public class ApplicationErrorResult : ObjectResult

    {

        public ApplicationErrorResult(object value) : base(value)

        {

            StatusCode = (int)HttpStatusCode.InternalServerError;

        }

    }




public class ErrorResponse

    {

        public ErrorResponse(string msg)

        {

            Message = msg;

        }

        public string Message { get; set; }

        public object DeveloperMessage { get; set; }

    }

注册全局过滤器

过滤器已经编写完毕,接下来就需要在asp.net core MVC中注册。找到系统根目录Startup.cs文件,修改ConfigureServices方法如下

 services.AddMvc(options =>
            {
                options.Filters.Add<HttpGlobalExceptionFilter>();
            });
测试

在请求中抛出一个异常

日志正确捕获到异常信息

浏览器返回500错误,并且返回自定义的错误信息。

相关文章: 

原文地址:http://www.cnblogs.com/huanent/p/7420039.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值