AdminResultProvider.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. namespace Admin.NET.Core;
  2. /// <summary>
  3. /// 全局规范化结果
  4. /// </summary>
  5. [UnifyModel(typeof(AdminResult<>))]
  6. public class AdminResultProvider : IUnifyResultProvider
  7. {
  8. /// <summary>
  9. /// 异常返回值
  10. /// </summary>
  11. /// <param name="context"></param>
  12. /// <param name="metadata"></param>
  13. /// <returns></returns>
  14. public IActionResult OnException(ExceptionContext context, ExceptionMetadata metadata)
  15. {
  16. return new JsonResult(RESTfulResult(metadata.StatusCode, errors: metadata.Errors));
  17. }
  18. /// <summary>
  19. /// 成功返回值
  20. /// </summary>
  21. /// <param name="context"></param>
  22. /// <param name="data"></param>
  23. /// <returns></returns>
  24. public IActionResult OnSucceeded(ActionExecutedContext context, object data)
  25. {
  26. return new JsonResult(RESTfulResult(StatusCodes.Status200OK, true, data));
  27. }
  28. /// <summary>
  29. /// 验证失败返回值
  30. /// </summary>
  31. /// <param name="context"></param>
  32. /// <param name="metadata"></param>
  33. /// <returns></returns>
  34. public IActionResult OnValidateFailed(ActionExecutingContext context, ValidationMetadata metadata)
  35. {
  36. return new JsonResult(RESTfulResult(metadata.StatusCode ?? StatusCodes.Status400BadRequest, errors: metadata.ValidationResult));
  37. }
  38. /// <summary>
  39. /// 特定状态码返回值
  40. /// </summary>
  41. /// <param name="context"></param>
  42. /// <param name="statusCode"></param>
  43. /// <param name="unifyResultSettings"></param>
  44. /// <returns></returns>
  45. public async Task OnResponseStatusCodes(HttpContext context, int statusCode, UnifyResultSettingsOptions unifyResultSettings)
  46. {
  47. // 设置响应状态码
  48. UnifyContext.SetResponseStatusCodes(context, statusCode, unifyResultSettings);
  49. switch (statusCode)
  50. {
  51. // 处理 401 状态码
  52. case StatusCodes.Status401Unauthorized:
  53. await context.Response.WriteAsJsonAsync(RESTfulResult(statusCode, errors: "401 登录已过期,请重新登录"),
  54. App.GetOptions<JsonOptions>()?.JsonSerializerOptions);
  55. break;
  56. // 处理 403 状态码
  57. case StatusCodes.Status403Forbidden:
  58. await context.Response.WriteAsJsonAsync(RESTfulResult(statusCode, errors: "403 禁止访问,没有权限"),
  59. App.GetOptions<JsonOptions>()?.JsonSerializerOptions);
  60. break;
  61. default: break;
  62. }
  63. }
  64. /// <summary>
  65. /// 返回 RESTful 风格结果集
  66. /// </summary>
  67. /// <param name="statusCode"></param>
  68. /// <param name="succeeded"></param>
  69. /// <param name="data"></param>
  70. /// <param name="errors"></param>
  71. /// <returns></returns>
  72. private static AdminResult<object> RESTfulResult(int statusCode, bool succeeded = default, object data = default, object errors = default)
  73. {
  74. return new AdminResult<object>
  75. {
  76. Code = statusCode,
  77. Message = errors is string str ? str : JSON.Serialize(errors),
  78. Result = data,
  79. Type = succeeded ? "success" : "error",
  80. Extras = UnifyContext.Take(),
  81. Timestamp = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds()
  82. };
  83. }
  84. }
  85. /// <summary>
  86. /// 全局返回结果
  87. /// </summary>
  88. /// <typeparam name="T"></typeparam>
  89. public class AdminResult<T>
  90. {
  91. /// <summary>
  92. /// 状态码
  93. /// </summary>
  94. public int Code { get; set; }
  95. /// <summary>
  96. /// 类型success、warning、error
  97. /// </summary>
  98. public string Type { get; set; }
  99. /// <summary>
  100. /// 错误信息
  101. /// </summary>
  102. public string Message { get; set; }
  103. /// <summary>
  104. /// 数据
  105. /// </summary>
  106. public T Result { get; set; }
  107. /// <summary>
  108. /// 附加数据
  109. /// </summary>
  110. public object Extras { get; set; }
  111. /// <summary>
  112. /// 时间戳
  113. /// </summary>
  114. public long Timestamp { get; set; }
  115. }