统一返回json数据封装
程序员文章站
2022-06-01 12:58:35
...
简介
首先,采用的是springboot,在controller中使用了@RestController或者@ResponseBody注解,返回的数据本身就是json格式。但是这样的json串在前后端分离使用中并不满足实际的效果,因此需要进行相应的封装,以满足前端能够正确处理获取的数据。
导入依赖(使用阿里的fastjson)
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.68</version>
</dependency>
统一返回规范
一般情况下,状态、信息、数据这三项已经满足大部分需要。
为空处理:利用fastjson自带的注解来处理返回时无值得情况,统一显示为null。@JSONField(serialzeFeatures = {SerializerFeature.WriteMapNullValue})
import java.io.Serializable;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.annotation.JSONField;
import com.alibaba.fastjson.serializer.SerializerFeature;
/**
*
* @Description: 统一API响应结果封装
* @author chenzuolin
* @date: 2020年06月29日
*/
public class ResponseBody implements Serializable {
private static final long serialVersionUID = 1886106011131539131L;
private String code;
private String message;
@JSONField(serialzeFeatures = {SerializerFeature.WriteMapNullValue})
private Object data;
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
public ResponseBody() {
super();
}
public ResponseBody(String code, String message, Object data) {
super();
this.code = code;
this.message = message;
this.data = data;
}
/**
* 默认成功或者失败,无数据
* @param resultCode
*/
public ResponseBody(ResultCode resultCode) {
this.code = resultCode.getCode();
this.message = resultCode.getMessage();
}
/**
* 枚举结果以及获取数据
* @param resultCode
* @param data
*/
public ResponseBody(ResultCode resultCode,String message) {
this.code = resultCode.getCode();
this.message = message;
}
/**
* 枚举结果以及获取数据
* @param resultCode
* @param data
*/
public ResponseBody(ResultCode resultCode,Object data) {
this.code = resultCode.getCode();
this.message = resultCode.getMessage();
this.data = data;
}
@Override
public String toString() {
return JSON.toJSONString(this);
}
}
统一封装状态码(枚举)
/**
*
* @Description: 响应码枚举,参考HTTP状态码的语义
* @author chenzuolin
* @date: 2020年06月29日
*/
public enum ResultCode {
SUCCESS("200", "Success!"),
FAIL("400", "Failure!"),
NO_PERMISSION("403", "Need Authorities!"),//没有权限
LOGIN_NO("402", "Need Login!"),//未登录
LOGIN_FAIL("401", "Login Failure!"),//登录失败
LOGIN_SUCCESS("200", "Login Success!"),//登录成功
LOGOUT_SUCCESS("200", "Logout Success!"),//退出登录
SESSION_EXPIRES("101", "Session Expires!"),//会话到期
SESSION_EXPIRES_OTHER_LOGIN("101", "Session Expires!Other users login!"),//会话到期,其他用户登录
private String code;
private String message;
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
/**
*
* @param code
* @param message
*/
ResultCode(String code, String message) {
this.code = code;
this.message = message;
}
}
利用**@Component**注解简化用户在返回数据是复杂复制操作,同时减少自定义的使用,以枚举为主,可以不断添加2
import org.springframework.stereotype.Component;
@Component
public class ResultGenerator{
/**
* 默认成功,无数据
* @return
*/
public ResponseBody getSuccessResult() {
return new ResponseBody(ResultCode.SUCCESS);
}
/**
* 默认成功,有数据
* @param data
* @return
*/
public ResponseBody getSuccessResult(Object data) {
return new ResponseBody(ResultCode.SUCCESS,data);
}
/**
* 默认失败,无数据
* @return
*/
public ResponseBody getFailResult() {
return new ResponseBody(ResultCode.FAIL);
}
/**
* 默认失败
* @param message 自定义失败信息
* @return
*/
public ResponseBody getFailResult(String message) {
return new ResponseBody(ResultCode.FAIL,message);
}
/**
* 采用枚举中的状态无数据返回
* @param resultCode 响应码枚举
* @param data
* @return
*/
public ResponseBody getFreeResult(ResultCode resultCode) {
return new ResponseBody(resultCode);
}
/**
* 采用枚举中的状态带数据返回
* @param resultCode 响应码枚举
* @param data
* @return
*/
public ResponseBody getFreeResult(ResultCode resultCode, Object data) {
return new ResponseBody(resultCode, data);
}
/**
* 自定义返回信息
* @param code 响应码
* @param message 自定义失败信息
* @param data
* @return
*/
public ResponseBody getFreeResult(String code, String message, Object data) {
return new ResponseBody(code, message, data);
}
}
示例
@Autowired
ResultGenerator resultGenerator;
@RequestMapping(value = "/user")
public ResponseBody json() {
List<SysUser> sysUser = sysUserService.selectSysUserByUnameOrCompany(null, null);
return resultGenerator.getSuccessResult(sysUser);
}
{
"code": "200",
"message": "Success!",
"data": [
{
"userId": 27,
"username": "admin1",
"password": "$2a$10$XlftNY9T52IbLlVAT6Nx7ezyYlcSFkVzC.3n3h5jihyzo1g/KtAPa",
"parentName": null,
"company": null
}
]
}
上一篇: javascript 判断当前浏览器版本并判断ie版本
下一篇: Linux删除重复行的代码
推荐阅读
-
javascript解析ajax返回的xml和json格式数据实例详解
-
Spring mvc实现Restful返回json格式数据实例详解
-
关于struts返回对象json格式数据的方法
-
java 通过发送json,post请求,返回json数据的方法
-
thinkphp5 + ajax 使用formdata提交数据(包括文件上传) 后台返回json完整实例
-
Springmvc 4.x利用@ResponseBody返回Json数据的方法
-
springMVC返回复杂的json格式数据方法
-
PHP以json或xml格式返回请求数据的方法
-
spring boot 2 全局统一返回RESTful风格数据、统一异常处理
-
LayUI数据接口返回实体封装的例子