GoViewResultProvider.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. namespace Admin.NET.Plugin.GoView.Util;
  10. /// <summary>
  11. /// GoView 规范化结果
  12. /// </summary>
  13. [UnifyModel(typeof(GoViewResult<>))]
  14. public class GoViewResultProvider : IUnifyResultProvider
  15. {
  16. /// <summary>
  17. /// 异常返回值
  18. /// </summary>
  19. /// <param name="context"></param>
  20. /// <param name="metadata"></param>
  21. /// <returns></returns>
  22. public IActionResult OnException(ExceptionContext context, ExceptionMetadata metadata)
  23. {
  24. return new JsonResult(RESTfulResult(metadata.StatusCode, data: metadata.Data, errors: metadata.Errors));
  25. }
  26. /// <summary>
  27. /// 成功返回值
  28. /// </summary>
  29. /// <param name="context"></param>
  30. /// <param name="data"></param>
  31. /// <returns></returns>
  32. public IActionResult OnSucceeded(ActionExecutedContext context, object data)
  33. {
  34. return new JsonResult(RESTfulResult(StatusCodes.Status200OK, true, data));
  35. }
  36. /// <summary>
  37. /// 验证失败返回值
  38. /// </summary>
  39. /// <param name="context"></param>
  40. /// <param name="metadata"></param>
  41. /// <returns></returns>
  42. public IActionResult OnValidateFailed(ActionExecutingContext context, ValidationMetadata metadata)
  43. {
  44. return new JsonResult(RESTfulResult(metadata.StatusCode ?? StatusCodes.Status400BadRequest, data: metadata.Data, errors: metadata.ValidationResult));
  45. }
  46. /// <summary>
  47. /// 特定状态码返回值
  48. /// </summary>
  49. /// <param name="context"></param>
  50. /// <param name="statusCode"></param>
  51. /// <param name="unifyResultSettings"></param>
  52. /// <returns></returns>
  53. public async Task OnResponseStatusCodes(HttpContext context, int statusCode, UnifyResultSettingsOptions unifyResultSettings)
  54. {
  55. // 设置响应状态码
  56. UnifyContext.SetResponseStatusCodes(context, statusCode, unifyResultSettings);
  57. switch (statusCode)
  58. {
  59. // 处理 401 状态码
  60. case StatusCodes.Status401Unauthorized:
  61. await context.Response.WriteAsJsonAsync(RESTfulResult(886, errors: "401 登录已过期,请重新登录"),
  62. App.GetOptions<JsonOptions>()?.JsonSerializerOptions);
  63. break;
  64. // 处理 403 状态码
  65. case StatusCodes.Status403Forbidden:
  66. await context.Response.WriteAsJsonAsync(RESTfulResult(statusCode, errors: "403 禁止访问,没有权限"),
  67. App.GetOptions<JsonOptions>()?.JsonSerializerOptions);
  68. break;
  69. default: break;
  70. }
  71. }
  72. /// <summary>
  73. /// 返回 RESTful 风格结果集
  74. /// </summary>
  75. /// <param name="statusCode"></param>
  76. /// <param name="succeeded"></param>
  77. /// <param name="data"></param>
  78. /// <param name="errors"></param>
  79. /// <returns></returns>
  80. private static GoViewResult<object> RESTfulResult(int statusCode, bool succeeded = default, object data = default, object errors = default)
  81. {
  82. return new GoViewResult<object>
  83. {
  84. Code = statusCode,
  85. Msg = errors is null or string ? (errors + "") : JSON.Serialize(errors),
  86. Data = data,
  87. Count = data != null && data.GetType().IsGenericType && data.GetType().GetGenericTypeDefinition() == typeof(List<>) ? ((IList)data).Count : null
  88. };
  89. }
  90. }
  91. /// <summary>
  92. /// GoView 返回结果
  93. /// </summary>
  94. /// <typeparam name="T"></typeparam>
  95. public class GoViewResult<T>
  96. {
  97. /// <summary>
  98. /// 状态码
  99. /// </summary>
  100. public int Code { get; set; }
  101. /// <summary>
  102. /// 信息
  103. /// </summary>
  104. public string Msg { get; set; }
  105. /// <summary>
  106. /// 数据
  107. /// </summary>
  108. public T Data { get; set; }
  109. /// <summary>
  110. /// 总数
  111. /// </summary>
  112. public int? Count { get; set; }
  113. }