.net core webapi 自定义异常过滤器
创始人
2024-11-05 07:12:36
0

1.定义统一返回格式

namespace webapi;  ///  /// 统一数据响应格式 ///  public class Results {     ///      /// 自定义的响应码,可以和http响应码一致,也可以不一致     ///      public int Code { get; set; }      ///      /// 中文消息提示     ///      public string? Msg { get; set; }      ///      /// 是否成功     ///      public bool Success { get; set; }      ///      /// 响应的数据     ///      public T? Data { get; set; }      ///      /// 返回的Token: 如果有值,则前端需要此这个值替旧的token值     ///      public string? Token { get; set; }      ///      /// 设置数据的结果     ///      /// 数据     ///      public static Results DataResult(T data)     {         return new Results { Code = 1, Data = data, Msg = "请求成功", Success = true };     }      ///      /// 响应成功的结果     ///      ///      ///      public static Results SuccessResult(string msg = "操作成功")     {         return new Results { Code = 1, Data = default, Msg = msg, Success = true };     }      ///      /// 响应失败的结果     ///      ///      ///      public static Results FailResult(string msg = "请求失败")     {         return new Results { Code = -1, Data = default, Msg = msg, Success = false };     }      ///      /// 参数有误     ///      ///      ///      public static Results InValidParameter(string msg = "参数有误")     {         return new Results { Code = -1, Data = default, Msg = msg, Success = false };     }      ///      /// 获取结果     ///      ///      ///      ///      ///      ///      public static Results GetResult(int code = 0, string? msg = null, T? data = default, bool success = true)     {         return new Results { Code = code, Data = data, Msg = msg, Success = success };     }      ///      /// 设置token结果     ///      ///      ///      public static Results TokenResult(string token)     {         return new Results { Code = 1, Data = default, Msg = "请求成功", Success = true, Token = token };     } } 

2.定义异常过滤器

using Microsoft.AspNetCore.Mvc.Filters; using Microsoft.AspNetCore.Mvc;  namespace webapi {     ///      /// 全局异常过滤器     ///      public class ExceptionFilter : Attribute, IExceptionFilter     {         private readonly ILogger _logger;          public ExceptionFilter(ILogger logger)         {             _logger = logger;         }          ///          /// 当发生异常的时候会执行此方法         ///          ///          ///          public void OnException(ExceptionContext context)         {             var values = context.RouteData.Values;             var controller = values["controller"];             var action = values["action"];             _logger.LogError($"控制器:{controller},方法:{action},详细信息:\n");             WriteDetailErrorMsg(context.Exception);             context.Result = new JsonResult(Results.FailResult(context.Exception.Message));         }          ///          /// 递归获取内部异常信息         ///          ///          ///          private void WriteDetailErrorMsg(Exception exception)         {             if (exception.InnerException != null)             {                 _logger.LogError(exception.StackTrace + "\n\n");                 WriteDetailErrorMsg(exception.InnerException);             }             else             {                 _logger.LogError("报错:" + exception.Message);                 _logger.LogError("堆栈跟踪:" + exception.StackTrace);             }         }     } } 

3.在控制器注入自定义的异常过滤器

             builder.Services.AddControllers(opt => {                 opt.Filters.Add();             }); 
4.定义一个错误的api接口 
        [HttpDelete]         public ActionResult Detele()         {             int i = 0;//除数不能为0;             return Content((1 / i).ToString());         } 

5.访问api接口
在这里插入图片描述
错误信息全记录到了,并输出到控制台,这里可以记录日志到文本文件或数据库。

相关内容

热门资讯

透视辅助(德州ai)其实真的有... 透视辅助(德州ai)其实真的有挂(透视)aapoker辅助是真的吗(详细透明挂教程)是一款可以让一直...
透视辅助(AApoker)其实... 透视辅助(AApoker)其实真的有挂(透视)wepoke打伙牌(详细透视教程)1、wepoke打伙...
透明辅助(德扑ai)其实真的有... 透明辅助(德扑ai)其实真的有挂(透视)wopoker用ai有用吗(详细透视教程)1、完成wopok...
透视辅助(AApoker)原来... 透视辅助(AApoker)原来真的有挂(透视)wpk德州辅助(详细辅助挂教程)是一款可以让一直输的玩...
透视辅助(红龙扑克)原来真的有... 透视辅助(红龙扑克)原来真的有挂(透视)wepoke有科技吗(详细辅助透视教程)1、起透看视 wep...
透视辅助(WePoKe)原来真... 透视辅助(WePoKe)原来真的有挂(透视)德州最新辅助器(详细辅助挂教程)1、起透看视 德州最新辅...
透明辅助(微扑克)原来真的有挂... 透明辅助(微扑克)原来真的有挂(透视)wepoke有挂吗网上靠谱吗(详细辅助透视教程)1、玩家可以在...
透视辅助(德州ai)其实真的有... 透视辅助(德州ai)其实真的有挂(透视)wepoke智能ai(详细透视教程)所有人都在同一条线上,像...
透视辅助(德州ai)原来真的有... 透视辅助(德州ai)原来真的有挂(透视)德扑ai决策软件(详细辅助挂教程)1、德扑ai决策软件系统规...
透视辅助(德扑ai)原来真的有... 透视辅助(德扑ai)原来真的有挂(辅助挂)wepower让系统发好牌(详细透视教程)1、wepowe...