Java设计通用的返回数据格式过程讲解
作者:shenzhenNBA 发布时间:2023-11-09 00:16:40
标签: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()使用
}
}
}
后记,项目主要框架代码,不全,但可以很清楚看清设计和使用了
来源:https://blog.csdn.net/shenzhenNBA/article/details/105336814


猜你喜欢
- 这次记录的是实现Android图片两手触控缩放的功能。编译环境:eclipseAndroid版本4.0创建工程过程略实现图片在页面两手触控缩
- import java.util.Arrays;/** * 栈的实现<br> * @author Skip&
- 我们可以试想ImageView能显示图片,而VideoView就是用来显示视频的。使用VideoView播放视频的步骤如下 【1】在界面布局
- 本文实例讲述了c#图像截取的实现方法。分享给大家供大家参考。具体如下:图像截取的相关代码如下: public Form1()&nb
- Android中的翻转动画效果的实现,首先看一下运行效果如上图所示. Android中并没有提供直接做3D翻转的动画,所以关于3D翻转的动画
- 一、相关知识SearchView控件:以下是几个简单网址:SearchView简单用法:Android搜索框(SearchView)的功能和
- 1、找准入口,使用ClassPathXmlApplicationContext的构造方法加载配置文件,用于加载classPath下的配置文件
- 目录1、synchronized锁的底层实现原理2、基于synchronized实现单例模式3、利用类加载实现单例模式(饿汉模式)1、syn
- 一、介绍在实际的软件项目开发过程中,我可以很负责任的跟大家说,如果你真的实际写代码的时间超过5年,你对增删改查这类简单的功能需求开发,可以说
- 场景最近在做数据分析项目,里面有这样一个业务:把匹配的数据打上标签,放到新的索引中。数据量:累计亿级的数据使用场景:可能会单次查询大量的数据
- C# multipart/form-data提交文件和参数public static string PostJsonData(string
- 添加记录后获取主键ID,这是一个很常见的需求,特别是在一次前端调用中需要插入多个表的场景。除了添加单条记录时获取主键值,有时候可能需要获取批
- 本文开始做一个网上商城的项目,首先从搭建环境开始,一步步
- 1 配置多数据源时,application.yml 的有关mybatis的配置是失效的,因为他不知道配置哪一个数据源2 applicatio
- 场景:假设每次我们去超市购物,我们都会推一个购物车,有水果、蔬菜、肉类三种商品,提供给我们选择,那么这时候,如果使用装饰器模式,应该如何实现
- 一、简介Mutex的突出特点是可以跨应用程序域边界对资源进行独占访问,即可以用于同步不同进程中的线程,这种功能当然这是以牺牲更多的系统资源为
- 核心思想:“分”与“合”。主体流程先将一个序列分成很多个不能再分割的子序列,将各个子序列分别排序后再将子序列合并。其实就是重复两个步骤:【1
- 1,编写一个程序,读取文件test.txt的内容并在控制台输出。如果源文件不存在,则显示相应的错误信息。 package src;impor
- 本文实例讲述了Android编程实现简单文件浏览器功能。分享给大家供大家参考,具体如下:运行效果:布局:<LinearLayout x
- 一、项目简述(+需求文档+PPT)功能: 主页显示热销商品;所有商品展示,可进行商品搜索;点 击商品进入商品详情页,显示库存,具有立即购买和