ExceptionHandlingMiddleware.cs 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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, SqlSugarClient db)
  27. {
  28. try
  29. {
  30. await _next(httpContext); //要么在中间件中处理,要么被传递到下一个中间件中去
  31. }
  32. catch (Exception ex)
  33. {
  34. await HandleExceptionAsync(httpContext, ex, db); // 捕获异常了 在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, SqlSugarClient db)
  44. {
  45. if (db.Ado != null && db.Ado.Transaction != null)
  46. {
  47. db.Ado.RollbackTran();
  48. }
  49. context.Response.ContentType = "application/json"; // 返回json 类型
  50. var response = context.Response;
  51. var errorResponse = new JsonView
  52. {
  53. Code = StatusCodes.Status500InternalServerError,
  54. Data = ""
  55. };
  56. // 自定义的异常错误信息类型
  57. switch (exception)
  58. {
  59. case ApplicationException ex:
  60. if (ex.Message.Contains("Invalid token"))
  61. {
  62. response.StatusCode = StatusCodes.Status403Forbidden;
  63. errorResponse.Msg = ex.Message;
  64. break;
  65. }
  66. response.StatusCode = StatusCodes.Status400BadRequest;
  67. errorResponse.Msg = ex.Message;
  68. break;
  69. case KeyNotFoundException ex:
  70. response.StatusCode = StatusCodes.Status404NotFound;
  71. errorResponse.Msg = ex.Message;
  72. break;
  73. case SqlSugarException ex:
  74. response.StatusCode = StatusCodes.Status204NoContent;
  75. if (ex.Message.Contains("timeout")) errorResponse.Msg = $"数据库连接超时,请稍后重试。";
  76. else errorResponse.Msg = ex.Message;
  77. break;
  78. default:
  79. response.StatusCode = StatusCodes.Status500InternalServerError;
  80. errorResponse.Msg = exception.Message;
  81. break;
  82. }
  83. _logger.LogError(exception.Message);
  84. var result = JsonConvert.SerializeObject(errorResponse);
  85. await context.Response.WriteAsync(result);
  86. }
  87. }
  88. }