Response.java 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. package space.anyi.serve.entity;
  2. import io.swagger.v3.oas.annotations.media.Schema;
  3. /**
  4. * @fileName: Response
  5. * @projectName: serve
  6. * @package: space.anyi.serve.entity
  7. * @author: 杨逸
  8. * @date:2026/4/1 9:03
  9. * @description:
  10. */
  11. @Schema(description = "后端统一的响应实体")
  12. public final class Response<T> {
  13. public static final Integer SUCCESS_CODE = 200;
  14. public static final Integer ERROR_CODE = 400;
  15. @Schema(description = "状态码;200:成功")
  16. private Integer code;
  17. @Schema(description = "响应附加信息")
  18. private String message;
  19. @Schema(description = "响应的具体数据")
  20. private T data;
  21. public Integer getCode() {
  22. return code;
  23. }
  24. public void setCode(Integer code) {
  25. this.code = code;
  26. }
  27. public String getMessage() {
  28. return message;
  29. }
  30. public void setMessage(String message) {
  31. this.message = message;
  32. }
  33. public T getData() {
  34. return data;
  35. }
  36. public void setData(T data) {
  37. this.data = data;
  38. }
  39. /**
  40. * 成功的封装
  41. * @param data 数据
  42. * @return {@code Response<T> }
  43. * @description:
  44. * @author: 杨逸
  45. * @data:2026/04/01 09:09:45
  46. * @since 1.0.0
  47. */
  48. public static <T> Response<T> ok(T data){
  49. Response<T> response = new Response<>();
  50. response.setCode(SUCCESS_CODE);
  51. response.setMessage("success");
  52. response.setData(data);
  53. return response;
  54. }
  55. public static <T> Response<T> ok(){
  56. Response<T> response = new Response<>();
  57. response.setCode(SUCCESS_CODE);
  58. response.setMessage("success");
  59. response.setData(null);
  60. return response;
  61. }
  62. /**
  63. * 失败的封装
  64. * @param message 错误信息
  65. * @return {@code Response<T> }
  66. * @description:
  67. * @author: 杨逸
  68. * @data:2026/04/01 09:09:51
  69. * @since 1.0.0
  70. */
  71. public static <T> Response<T> error(String message){
  72. Response<T> response = new Response<>();
  73. response.setCode(ERROR_CODE);
  74. response.setMessage(message);
  75. return response;
  76. }
  77. public static <T> Response<T> error(String message,T data){
  78. Response<T> response = new Response<>();
  79. response.setCode(ERROR_CODE);
  80. response.setMessage(message);
  81. response.setData(data);
  82. return response;
  83. }
  84. /**
  85. * 自定义封装
  86. * @param code 状态码
  87. * @param message 信息
  88. * @param data 数据
  89. * @return {@code Response<T> }
  90. * @description:
  91. * @author: 杨逸
  92. * @data:2026/04/01 09:12:31
  93. * @since 1.0.0
  94. */
  95. public static <T> Response<T> of(Integer code,String message,T data){
  96. Response<T> response = new Response<>();
  97. response.setCode(code);
  98. response.setMessage(message);
  99. response.setData(data);
  100. return response;
  101. }
  102. }