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

Posted wx5cb71f4b705da

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高复用服务响应对象的设计思想以及抽象封装相关的知识,希望对你有一定的参考价值。


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 = data;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
* @param data
*/
private ServerResponse(int status, String msg, T data)
this.status = status;
this.msg = msg;
this.data = 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 = data;


/**
* 私有构造器,在调用公共方法时,使用
* @param status
* @param msg
* @param data
*/
private ServerResponse(int status, String msg, T data)
this.status = status;
this.msg = msg;
this.data = 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);


以上是关于高复用服务响应对象的设计思想以及抽象封装的主要内容,如果未能解决你的问题,请参考以下文章

高复用性响应对象类

UED团队规范设计参考及建议

设计模式精要

前端通用组件设计

java基础---抽象和封装

CAPL 封装了的SeedKey解锁函数,高复用性