Java设计通用的返回数据格式过程讲解

 更新时间:2023年05月17日 10:34:29   作者:shenzhenNBA  
现在很多的项目server端返回client端的数据多数以JSON格式返回,同时结合其它需要,通常加一下状态码和信息之类,给前端处理带来很大的方便,这篇文章就用Java设计了通用的返回数据格式,感兴趣的同学可以参考下文

相信在做B/S模式的项目时,我们请求server端时通常遇到返回数据的处理,对返回数据的格式处理方式多样,随着JSON的流行,现在很多的项目server端返回client端的数据多数以JSON格式返回,同时结合其它需要,通常加一下状态码和信息之类,给前端处理带来很大的方便,那我们今天就来看看一种通用返回结果的设计和应用;

一,通用返回结果的信息类

这个主要是做返回结果信息的载体类,含有关键的结果代码,结果信息,结果数据,基本满足前端的需要关键信息,其中数据以泛型使其可以保存任意数据类型,通用代码如下:

public class ResultInfo<T> {
	//通用返回信息对象类
	private int code;   //返回状态码
	private String msg;	//返回信息
	private T data;     //返回数据
	public ResultInfo<T> setCode(int code){
		this.code = code;
		return this;
	}
	public int getCode(){		
		return this.code;
	}
	public ResultInfo<T> setMsg(String msg){
		this.msg = msg;
		return this;
	}
	public String getMsg(){		
		return this.msg;
	}
	public ResultInfo<T> setData(T data){
		this.data = data;
		return this;
	}
	public T getData(){		
		return this.data;
	}
	//more functon here...
}

二,通用返回结果信息的方法类

提供各种通用的返回方法,以便在Controller层直接使用,通常设计如下:

public class Result {
	//通用返回结果的方法类
	private static final int okCode = 0;
	private static final int failCode = 1;
	private static final String okMsg = "操作成功";
	private static final String failMsg = "操作失败";
	//以上这些通常可以定义为一种枚举类,然后使用
	//成功返回方法
	public static <T> ResultInfo<T> Ok(){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(okCode).setMsg(okMsg);
		return r;
	}
	public static <T> ResultInfo<T> Ok(String msg){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(okCode).setMsg(msg);
		return r;
	}
	public static <T> ResultInfo<T> Ok(T data){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(okCode).setMsg(okMsg).setData(data);
		return r;
	}
	public static <T> ResultInfo<T> Ok(String msg, T data){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(okCode).setMsg(msg).setData(data);
		return r;
	}
	//失败返回方法
	public static <T> ResultInfo<T> Fail(){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(failCode).setMsg(failMsg);
		return r;
	}
	public static <T> ResultInfo<T> Fail(String msg){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(failCode).setMsg(msg);
		return r;
	}
	public static <T> ResultInfo<T> Fail(T data){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(failCode).setMsg(failMsg).setData(data);
		return r;
	}
	public static <T> ResultInfo<T> Fail(String msg, T data){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(failCode).setMsg(msg).setData(data);
		return r;
	}
	//通用返回方法
	public static <T> ResultInfo<T> result(int code, String msg){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(code).setMsg(msg);
		return r;
	}
	public static <T> ResultInfo<T> result(int code, String msg, T data){
		ResultInfo<T> r = new ResultInfo<T>();
		r.setCode(code).setMsg(msg).setData(data);
		return r;
	}
}

三,在Controller层中的使用

package com.xxx.yyy.zzz.controller;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import com.xxx.yyy.zzz.util.ResultInfo;
import com.xxx.yyy.zzz.util.Result;
import com.xxx.yyy.zzz.model.User;
import com.xxx.yyy.zzz.service.UserService;
import org.springframework.stereotype.Controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.ResquestBody;
// more import ...
/**
* 用户对外API
* @author shenzhenNBA
* @since 2020.03.05
* 通用返回结果的应用
*/
@RequestMapping("/user")
@Controller
public class UserController {
	private static Log Logger = LogFactory.getLog(UserController.class);
	@Autowired
	UserService userService; //需另外定义,此处省略
	/**
	* 保存用户,
	* 返回格式: {"code":xx,"msg":"yyy","data":null}
	*/
	@PostMapping(value="/save")
	@ResponseBody
	public ResultInfo<String> saveUser(@RequestBody User param){
		try{
			int num = userService.saveUser(param);
			if (0 == num) {
				return Ok("保存成功"); //通用方法Ok()使用
			} else if (1 == num) {
				return Fail("失败,参数异常");  //通用方法Fail()使用
			} else if (2 == num) {
				return Fail("失败,保持操作失败");
			} else {
				return Fail("失败,未知异常");
			}
		} catch (Exception e) {
			Logger.error("controller UserController.saveUser() error, param: {}, info: {}", param, e)
			return Fail("保存失败,过程出现异常");
		}		
	}
	/**
	* 根据记录ID获取用户记录信息,
	* 返回格式: {"code":xx,"msg":"yyy","data":User对象JSON格式字符串}
	*/
	@PostMapping(value="/getById")
	@ResponseBody
	public ResultInfo<User> getById(@RequestBody UserParam param){
		try{
			User user = userService.getById(param);
			return Ok("查询成功", user);  //通用方法Ok()使用
		} catch (Exception e) {
			Logger.error("controller UserController.getById() error, param: {}, info: {}", param, e)
			return Fail("查询失败,过程出现异常",null); //通用方法Fail()使用
		}
	}	
}

后记,项目主要框架代码,不全,但可以很清楚看清设计和使用了

到此这篇关于Java设计通用的返回数据格式过程讲解的文章就介绍到这了,更多相关Java返回数据格式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java多线程间的5种通信方式小结

    Java多线程间的5种通信方式小结

    有两个线程,A 线程向一个集合里面依次添加元素“abc”字符串,一共添加十次,当添加到第五次的时候,希望 B 线程能够收到 A 线程的通知,然后 B 线程执行相关的业务操作,本文介绍的5种通信方式都是基本这两种模型来实现的,需要的朋友可以参考下
    2023-10-10
  • SpringBoot中的@DependsOn注解详解

    SpringBoot中的@DependsOn注解详解

    这篇文章主要介绍了SpringBoot中的@DependsOn注解详解,
    2023-08-08
  • 解析Java中的定时器及使用定时器制作弹弹球游戏的示例

    解析Java中的定时器及使用定时器制作弹弹球游戏的示例

    这篇文章主要介绍了Java中的定时器及使用定时器制作弹弹球游戏的示例,文中同时也分析了定时器timer的缺点及相关替代方案,需要的朋友可以参考下
    2016-02-02
  • Java泛型 <T> T、 T、<T>的用法小结

    Java泛型 <T> T、 T、<T>的用法小结

    T在Java泛型中,被称作类型变量, 有的方法返回值是<T> T,有的是T,区别在哪里,本文主要介绍了Java泛型 <T> T、 T、<T>的用法小结,具有一定的参考价值,感兴趣的可以了解下
    2023-12-12
  • 一文掌握JVM Safe Point

    一文掌握JVM Safe Point

    关于 Safe Point 是 JVM 中很关键的一个概念,但我估计有不少同学不是很懂,于是今天跟大家来深入聊聊 Safe Point,通过本文学习你会了解什么是 Safe Point?为啥需要 Safe Point?Safe Point 与 Stop the World 的关系?感兴趣的朋友一起看看吧
    2022-10-10
  • Java快速排序与归并排序及基数排序图解示例

    Java快速排序与归并排序及基数排序图解示例

    快速排序是基于二分的思想,对冒泡排序的一种改进。主要思想是确立一个基数,将小于基数的数放到基数左边,大于基数的数字放到基数的右边,然后在对这两部分进一步排序,从而实现对数组的排序
    2022-09-09
  • 如何获得spring上下文的方法总结

    如何获得spring上下文的方法总结

    这篇文章主要介绍了如何获得spring上下文的方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Java正则提取中括号中的内容操作示例

    Java正则提取中括号中的内容操作示例

    这篇文章主要介绍了Java正则提取中括号中的内容操作,涉及Java针对字符串的正则匹配、转换、遍历等相关操作技巧,需要的朋友可以参考下
    2018-06-06
  • java8 stream 由一个list转化成另一个list案例

    java8 stream 由一个list转化成另一个list案例

    这篇文章主要介绍了java8 stream 由一个list转化成另一个list案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • Java实现简易计算器(逆波兰表达式)

    Java实现简易计算器(逆波兰表达式)

    这篇文章主要为大家详细介绍了Java实现简易计算器,逆波兰表达式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07

最新评论