ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CoreApi 3.1 - 全局异常处理的几种方式

2020-10-14 13:00:43  阅读:278  来源: 互联网

标签:CoreApi Response public ex context 3.1 全局 next httpContext


一、过滤器方式

先定义一个异常过滤器

    /// <summary>
    /// 异常过滤器
    /// </summary>
    public class ExceptionFilter : IExceptionFilter
    {
        /// <summary>
        /// 发生异常时进入
        /// </summary>
        /// <param name="context"></param>
        public void OnException(ExceptionContext context)
        {
            if (context.ExceptionHandled == false)
            {
                context.Result = new ContentResult
                {
                    Content = context.Exception.Message,//这里是把异常输出,也可以不输出,也可以输出JSON结构的字符串。
                    StatusCode = StatusCodes.Status200OK,
                    ContentType = "text/html;charset=utf-8"
                };
            }
            context.ExceptionHandled = true;

            //写入日志,或者其它操作
            
        }
    }

再API控制器使用过滤器

[TypeFilter(typeof(ExceptionFilter))]//这里使用自定义过滤器
[ApiController]
public class MyController:ControllerBase
{
    //.....          
}

 

二、配置方式

在 Startup.cs 中的, Configure 配置中

        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            //异常配置文件写法
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            else
            {
                app.UseExceptionHandler(config =>
                {
                    config.Run(async context =>
                    {
                        context.Response.StatusCode = 500;
                        context.Response.ContentType = "application/json";

                        var error = context.Features.Get<IExceptionHandlerFeature>();
                        if (error != null)
                        {
                            var ex = error.Error;

                            //输出异常内容,也可以不输出,也可以输出JSON结构的字符串
                            await context.Response.WriteAsync(ex.Message);
                        }
                    });
                });
            }
        }

 

三、中间件方式

先定义一个异常中间件

    public class CustomExceptionMiddleware
    {
        private readonly RequestDelegate _next;
        //private readonly ILogger<CustomExceptionMiddleware> _logger;
        public CustomExceptionMiddleware(RequestDelegate next)
        {
            _next = next;
        }

        public async Task Invoke(HttpContext httpContext)
        {
            try
            {
                await _next(httpContext);
            }
            catch (Exception ex)
            {
                //写入日志或者其它操作
                //log
                await HandleExceptionAsync(httpContext, ex);
            }
        }

        private async Task HandleExceptionAsync(HttpContext httpContext, Exception ex)
        {
            httpContext.Response.StatusCode = StatusCodes.Status200OK;
            httpContext.Response.ContentType = "application/json;charset=utf-8";
            //输出异常内容
            await httpContext.Response.WriteAsync(ex.Message);
            //如果不输出,则需要下面这句
            //return Task.CompletedTask;
        }
    }

 

 再定义一个扩展类

    public static class CustomExceptionMiddlewareExtensions
    {
        public static IApplicationBuilder UseCustomExceptionMiddleware(this IApplicationBuilder builder)
        {
            return builder.UseMiddleware<CustomExceptionMiddleware>();
        }
    }

 

在 Startup 的 Configure 中配置

app.UseCustomExceptionMiddleware();

 

放在最前面

 

标签:CoreApi,Response,public,ex,context,3.1,全局,next,httpContext
来源: https://www.cnblogs.com/myfqm/p/13814201.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有