ApiResult.cs 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. using Infrastructure.Constant;
  2. using Newtonsoft.Json;
  3. namespace Infrastructure.Model
  4. {
  5. /// <summary>
  6. /// 统一的API返回结果类
  7. /// </summary>
  8. public class ApiResult
  9. {
  10. /// <summary>
  11. /// 返回码
  12. /// </summary>
  13. public int Code { get; set; }
  14. /// <summary>
  15. /// 返回信息
  16. /// </summary>
  17. public string Msg { get; set; }
  18. /// <summary>
  19. /// 如果data值为null,则忽略序列化将不会返回data字段
  20. /// </summary>
  21. [JsonProperty(NullValueHandling = NullValueHandling.Ignore)]
  22. public object Data { get; set; }
  23. /// <summary>
  24. /// 初始化一个新创建的APIResult对象,使其表示一个空消息
  25. /// </summary>
  26. public ApiResult()
  27. {
  28. }
  29. /// <summary>
  30. /// 初始化一个新创建的 ApiResult 对象
  31. /// </summary>
  32. /// <param name="code">返回码</param>
  33. /// <param name="msg">返回信息</param>
  34. public ApiResult(int code, string msg)
  35. {
  36. Code = code;
  37. Msg = msg;
  38. }
  39. /// <summary>
  40. /// 初始化一个新创建的 ApiResult 对象
  41. /// </summary>
  42. /// <param name="code">返回码</param>
  43. /// <param name="msg">返回信息</param>
  44. /// <param name="data">返回数据</param>
  45. public ApiResult(int code, string msg, object data)
  46. {
  47. Code = code;
  48. Msg = msg;
  49. if (data != null)
  50. {
  51. Data = data;
  52. }
  53. }
  54. /// <summary>
  55. /// 返回成功消息
  56. /// </summary>
  57. /// <returns></returns>
  58. public ApiResult Success()
  59. {
  60. Code = (int)ResultCode.SUCCESS;
  61. Msg = "success";
  62. return this;
  63. }
  64. /// <summary>
  65. /// 返回成功消息
  66. /// </summary>
  67. /// <param name="data">数据对象</param>
  68. /// <returns>成功消息</returns>
  69. public static ApiResult Success(object data)
  70. {
  71. return new ApiResult(HttpStatus.SUCCESS, "success", data);
  72. }
  73. /// <summary>
  74. /// 返回成功消息
  75. /// </summary>
  76. /// <param name="msg">返回内容</param>
  77. /// <returns>成功消息</returns>
  78. public static ApiResult Success(string msg)
  79. {
  80. return new ApiResult(HttpStatus.SUCCESS, msg, null);
  81. }
  82. /// <summary>
  83. /// 返回成功消息
  84. /// </summary>
  85. /// <param name="msg">返回内容</param>
  86. /// <param name="data">返回的数据对象</param>
  87. /// <returns>成功消息</returns>
  88. public static ApiResult Success(string msg, object data)
  89. {
  90. return new ApiResult(HttpStatus.SUCCESS, msg, data);
  91. }
  92. /// <summary>
  93. /// 访问被拒
  94. /// </summary>
  95. public ApiResult On401()
  96. {
  97. Code = (int)ResultCode.DENY;
  98. Msg = "access denyed";
  99. return this;
  100. }
  101. /// <summary>
  102. /// 返回失败消息
  103. /// </summary>
  104. /// <param name="code">错误码</param>
  105. /// <param name="msg">返回的失败信息</param>
  106. /// <returns></returns>
  107. public static ApiResult Error(int code, string msg)
  108. {
  109. return new ApiResult(code, msg);
  110. }
  111. /// <summary>
  112. /// 返回失败消息
  113. /// 自定义异常
  114. /// </summary>
  115. /// <param name="msg">返回的失败信息</param>
  116. /// <returns></returns>
  117. public static ApiResult Error(string msg)
  118. {
  119. return new ApiResult((int)ResultCode.CUSTOM_ERROR, msg);
  120. }
  121. public override string ToString()
  122. {
  123. return $"msg={Msg},data={Data}";
  124. }
  125. }
  126. public class ApiResult<T> : ApiResult
  127. {
  128. public T Result { get; set; }
  129. }
  130. }