ExceptionHandlingMiddleware.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. 
  2. namespace OASystem.API.Middlewares
  3. {
  4. /// <summary>
  5. /// 全局异常捕获中间件
  6. /// </summary>
  7. public class ExceptionHandlingMiddleware
  8. {
  9. private readonly RequestDelegate _next; // 用来处理上下文请求
  10. private readonly ILogger<ExceptionHandlingMiddleware> _logger;
  11. /// <summary>
  12. /// 初始化
  13. /// </summary>
  14. /// <param name="next"></param>
  15. /// <param name="logger"></param>
  16. public ExceptionHandlingMiddleware(RequestDelegate next, ILogger<ExceptionHandlingMiddleware> logger)
  17. {
  18. _next = next;
  19. _logger = logger;
  20. }
  21. /// <summary>
  22. /// 执行中间件
  23. /// </summary>
  24. /// <param name="httpContext"></param>
  25. /// <returns></returns>
  26. public async Task InvokeAsync(HttpContext httpContext)
  27. {
  28. try
  29. {
  30. await _next(httpContext); //要么在中间件中处理,要么被传递到下一个中间件中去
  31. }
  32. catch (Exception ex)
  33. {
  34. await HandleExceptionAsync(httpContext, ex); // 捕获异常了 在HandleExceptionAsync中处理
  35. }
  36. }
  37. /// <summary>
  38. /// 异步处理异常
  39. /// </summary>
  40. /// <param name="context"></param>
  41. /// <param name="exception"></param>
  42. /// <returns></returns>
  43. private async Task HandleExceptionAsync(HttpContext context, Exception exception)
  44. {
  45. context.Response.ContentType = "application/json"; // 返回json 类型
  46. var response = context.Response;
  47. var errorResponse = new JsonView
  48. {
  49. Code = StatusCodes.Status500InternalServerError,
  50. Data = ""
  51. };
  52. // 自定义的异常错误信息类型
  53. switch (exception)
  54. {
  55. case ApplicationException ex:
  56. if (ex.Message.Contains("Invalid token"))
  57. {
  58. response.StatusCode = StatusCodes.Status403Forbidden;
  59. errorResponse.Msg = ex.Message;
  60. break;
  61. }
  62. response.StatusCode = StatusCodes.Status400BadRequest;
  63. errorResponse.Msg = ex.Message;
  64. break;
  65. case KeyNotFoundException ex:
  66. response.StatusCode = StatusCodes.Status404NotFound;
  67. errorResponse.Msg = ex.Message;
  68. break;
  69. case SqlSugarException ex:
  70. response.StatusCode = StatusCodes.Status204NoContent;
  71. if (ex.Message.Contains("timeout")) errorResponse.Msg = $"数据库连接超时,请稍后重试。";
  72. else errorResponse.Msg = ex.Message;
  73. break;
  74. default:
  75. response.StatusCode = StatusCodes.Status500InternalServerError;
  76. errorResponse.Msg = exception.Message;
  77. break;
  78. }
  79. _logger.LogError(exception.Message);
  80. var result = JsonConvert.SerializeObject(errorResponse);
  81. await context.Response.WriteAsync(result);
  82. }
  83. }
  84. }