高复用服务响应对象的设计思想以及抽象封装

知识就是力量,时间就是生命。这篇文章主要讲述高复用服务响应对象的设计思想以及抽象封装相关的知识,希望能为你提供帮助。


1. 用途作为控制层统一返回对象
2. 参数【高复用服务响应对象的设计思想以及抽象封装】status:状态 int

  • msg:返回信息 String
  • data:范型对象 T
;
//返回信息
private String msg;
//返回对象
private T data;

3. 私有构造器
(int status)
this.status = status;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
*/
private ServerResponse(int status, String msg)
this.status = status;
this.msg = msg;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param data
*/
private ServerResponse(int status, T data)
this.status = status;
this.data = https://www.songbingjia.com/android/data;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
* @param data
*/
private ServerResponse(int status, String msg, T data)
this.status = status;
this.msg = msg;
this.data = https://www.songbingjia.com/android/data;

  • 疑问
(int status, T data)
// 和ServerResponse(int status, String msd)调用哪一个?

  • 解决
(String[] args)
ServerResponse s1 = new ServerResponse(1, new Object());
ServerResponse s2 = new ServerResponse(1, "ss");
System.out.println("aaa"); //加入断点调试

  • 调试结果:

4. 设置返回状态码
/**
* 返回状态码
*/
public enum ResponseCode

SUCCESS(0,"SUCCESS"),

ERROR(1,"ERROR"),

NEED_LOGIN(10, "NEED_LOGIN"),

ILLEGAL_ARGUMENT(2, "ILLEGAL_ARGUMENT");


private final int code;

private final String desc;

//必须加上构造器
ResponseCode(int code, String desc)
this.code = code;
this.desc = desc;



public int getCode()
return code;


public String getDesc()
return desc;

5. 设置静态返回方法,包括成功与失败
< T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess()
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode());


/**
* 公共静态成功返回方法
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess(String msg)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(), msg);


/**
* 公共静态成功返回方法
* @param data
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess(T data)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(),data);


/**
* 公共静态成功返回方法
* @param msg
* @param data
* @param < T>
* @return
*/
//解决String与data同时传输的问题
public static < T> ServerResponse< T> createBySuccess(String msg, T data)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(), msg, data);


/**
* 公共静态失败返回方法
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError()
return new ServerResponse< T> (ResponseCode.ERROR.getCode(), ResponseCode.ERROR.getDesc());


/**
* 公共静态失败返回方法,返回默认失败信息
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError(String msg)
return new ServerResponse< T> (ResponseCode.ERROR.getCode(), msg);


/**
* 公共静态失败返回方法,根据状态码自定义失败信息
* @param code
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError(int code,String msg)
return new ServerResponse< T> (code, msg);

6. 公共方法序列化忽略
()
return this.status == ResponseCode.SUCCESS.getCode();

7. 返回NULL字段序列化忽略
/**
* 高复用返回封装对象
* @param < T>
*/
//JSON序列化忽略是NULL的字段,主要是失败时的data不显示
@JsonSerialize(include = JsonSerialize.Inclusion.NON_NULL)
public class ServerResponse< T> implements Serializable

8. 完整代码
package cn.hcnet2006.mmall.mmall.common;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.jsonschema.JsonSerializableSchema;
import org.springframework.web.servlet.function.ServerRequestExtensionsKt;

import java.io.Serializable;

/**
* 高复用返回封装对象
* @param < T>
*/
//JSON序列化忽略是NULL的字段,主要是失败时的data不显示
@JsonSerialize(include = JsonSerialize.Inclusion.NON_NULL)
public class ServerResponse< T> implements Serializable

//返回状态
private int status;
//返回信息
private String msg;
//返回对象
private T data;

/**
* 私有构造器,在调用公共方法时,使用
* @param status
*/
private ServerResponse(int status)
this.status = status;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
*/
private ServerResponse(int status, String msg)
this.status = status;
this.msg = msg;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param data
*/
private ServerResponse(int status, T data)
this.status = status;
this.data = https://www.songbingjia.com/android/data;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
* @param data
*/
private ServerResponse(int status, String msg, T data)
this.status = status;
this.msg = msg;
this.data = https://www.songbingjia.com/android/data;


/**
* 公共开放方法
* @return
*/
//序列化不会显示在JSON里面
@JsonIgnore
public boolean isSuccess()
return this.status == ResponseCode.SUCCESS.getCode();

/**
* 公共开放方法
*/
public int getStatus()
return status;

/**
* 公共开放方法
*/
public String getMsg()
return msg;

/**
* 公共开放方法
*/
public T getData()
return data;


/**
* 公共静态成功返回方法
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess()
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode());


/**
* 公共静态成功返回方法
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess(String msg)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(), msg);


/**
* 公共静态成功返回方法
* @param data
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createBySuccess(T data)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(),data);


/**
* 公共静态成功返回方法
* @param msg
* @param data
* @param < T>
* @return
*/
//解决String与data同时传输的问题
public static < T> ServerResponse< T> createBySuccess(String msg, T data)
return new ServerResponse< T> (ResponseCode.SUCCESS.getCode(), msg, data);


/**
* 公共静态失败返回方法
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError()
return new ServerResponse< T> (ResponseCode.ERROR.getCode(), ResponseCode.ERROR.getDesc());


/**
* 公共静态失败返回方法,返回默认失败信息
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError(String msg)
return new ServerResponse< T> (ResponseCode.ERROR.getCode(), msg);


/**
* 公共静态失败返回方法,根据状态码自定义失败信息
* @param code
* @param msg
* @param < T>
* @return
*/
public static < T> ServerResponse< T> createByError(int code,String msg)
return new ServerResponse< T> (code, msg);





    推荐阅读