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

简介

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

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

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

public class HttpGlobalExceptionFilter : IExceptionFilter

    {

        public void OnException(ExceptionContext context)

        {

            throw new NotImplementedException();

        }

    }

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

///

    /// 全局异常过滤器

    ///

    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();
            });

测试

在请求中抛出一个异常

asp.net core MVC 过滤器之ExceptionFilter过滤器(一)_第1张图片

日志正确捕获到异常信息

asp.net core MVC 过滤器之ExceptionFilter过滤器(一)_第2张图片

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

asp.net core MVC 过滤器之ExceptionFilter过滤器(一)_第3张图片

相关文章: 

  • .NET Core 2.0 正式发布信息汇总

  • .NET Standard 2.0 特性介绍和使用指南

  • .NET Core 2.0 的dll实时更新、https、依赖包变更问题及解决

  • .NET Core 2.0 特性介绍和使用指南

  • Entity Framework Core 2.0 新特性

  • 体验 PHP under .NET Core

  • .NET Core 2.0使用NLog

  • 升级项目到.NET Core 2.0,在Linux上安装Docker,并成功部署

  • 解决Visual Studio For Mac Restore失败的问题

  • ASP.NET Core 2.0 特性介绍和使用指南

  • .Net Core下通过Proxy 模式 使用 WCF

  • .NET Core 2.0 开源Office组件 NPOI

  • ASP.NET Core Razor页面 vs MVC

  • Razor Page–Asp.Net Core 2.0新功能  Razor Page介绍

  • MySql 使用 EF Core 2.0 CodeFirst、DbFirst、数据库迁移(Migration)介绍及示例

  • .NET Core 2.0迁移技巧之web.config配置文件

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


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

640?wx_fmt=jpeg

你可能感兴趣的:(asp.net core MVC 过滤器之ExceptionFilter过滤器(一))