前言

目前大部分系统都是前后端分离架构,后端提供接口并返回 JSON 数据,前端接收数据后进行处理展示。为了提高前后端协作效率,后端接口返回值采用固定格式十分必要。

后端接口返回值通用格式

通用返回值通常包含 4 个核心字段,代码定义如下:

public class Result<T> {/*** 请求是否处理成功*/private boolean success;/*** 数据,泛型类型,存储后端返回给前端的业务数据*/private T data;/*** 提示消息,当success为false时给用户的提示信息*/private String msg;/*** 错误编码,提供详细错误标识,便于前端根据不同编码做差异化处理*/private String code;
}

接口示例

@RestController
public class TestController {@GetMapping("/hello")public Result<String> hello() {return ResultUtils.success("hello");}}

前端接收结果

{"success": true,"data": "hello","msg": null,"code": null
}

异常情况处理

后端接口通常包含校验逻辑,如登录接口需要验证用户名和密码。当验证不通过时,应返回标准化的错误信息:

{"success": false,"data": null,"msg": "用户名或密码错误","code": "1001"}

实现方式:后端校验不通过时抛出业务异常,通过全局异常处理器统一处理并返回通用格式结果。

具体实现步骤

1. 自定义业务异常类

public class BusinessException extends RuntimeException {private String code;/*** @param code    错误编码* @param message 错误提示信息*/public BusinessException(String code, String message) {super(message);this.code = code;}public BusinessException(String code, String message, Throwable cause) {super(message, cause);this.code = code;}public String getCode() {return code;}public void setCode(String code) {this.code = code;}
}

2. 接口中抛出业务异常

以登录接口为例,当用户名验证不通过时抛出异常:

@GetMapping("/login")
public Result<String> login(String name) {if (!"chen".equals(name)) {throw new BusinessException("1001", "用户名错误");} else {return ResultUtils.success("登录成功");}
}

3. 全局异常处理 BusinessException

使用 SpringBoot 的全局异常处理器处理业务异常,通过@RestControllerAdvice和@ExceptionHandler注解实现:

@RestControllerAdvice
public class GlobalExceptionHandler {private Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);/*** 处理业务异常** @param e       业务异常对象* @param request 请求对象* @return 通用返回结果*/@ExceptionHandler(BusinessException.class)public Result handleBusinessException(BusinessException e, HttpServletRequest request) {logger.info("请求:{},发生异常:{}", request.getRequestURL(), e.getMessage(), e);return ResultUtils.error(e.getCode(), e.getMessage());}}

4. 验证效果

  • 正常情况(访问:http://localhost:8080/login?name=chen):
{"success": true,"data": "登录成功","msg": null,"code": null
}
  • 异常情况(访问:http://localhost:8080/login?name=张三):
{"success": false,"data": null,"msg": "用户名错误","code": "1001"
}

案例:SpringBoot 参数校验异常处理

SpringBoot 提供参数自动校验功能,以下是具体实现:

1. 用户注册接口

@PostMapping("/userRegister")public Result<Void> userRegister(@Validated @RequestBody UserRegisterRequest req) {return ResultUtils.success();}

2. 参数校验异常处理

当参数校验不通过时,SpringBoot 会抛出BindException异常,在全局异常处理器中添加对应处理方法:

@ExceptionHandler(BindException.class)public Result handleBindException(BindException e, HttpServletRequest request) {logger.info("请求:{},发生异常:{}", request.getRequestURL(), e.getMessage(), e);String message = e.getAllErrors().get(0).getDefaultMessage();return ResultUtils.error(message);}

全局其他异常处理

添加兜底异常处理方法,处理所有未被专门捕获的异常:


/*** 处理其他未明确捕获的异常** @param e 异常对象* @param request 请求对象* @return 通用返回结果*/@ExceptionHandler(Exception.class)public Result handleException(Exception e, HttpServletRequest request) {logger.info("请求:{},发生异常:{}", request.getRequestURL(), e.getMessage(), e);return ResultUtils.error(ErrorCode.SERVER_ERROR, "系统异常,请稍后重试");}

提供的工具类

ResultUtils

public class ResultUtils {public static final String SUCCESS = "1";public static final String ERROR = "0";public static <T> Result<T> ok(){return result(SUCCESS, null, null);}public static <T> Result<T> ok(T data){return result(SUCCESS, data, null);}public static <T> Result<T> error(String msg){return result(ERROR, null, msg);}public static <T> Result<T> result(String code, T data, String msg){Result<T> r = new Result<>();r.setCode(code);r.setData(data);r.setMsg(msg);return r;}
}

BusinessExceptionUtils

public class BusinessExceptionUtils
{/*** 创建 BusinessException*/public static BusinessException businessException(String code, String msg){return new BusinessException(code, msg);}
}

ErrorCode

public class ErrorCode
{public static final String SERVER_ERROR = "500";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/91266.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/91266.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/91266.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【yolo】模型训练参数解读

在YOLO&#xff08;You Only Look Once&#xff09;目标检测模型的训练过程中&#xff0c;数据增强是一项至关重要且极具“艺术性”的技术。它通过对训练图像进行一系列随机变换&#xff0c;人为地创造出更多样化的训练样本&#xff0c;从而有效提升模型的泛化能力、鲁棒性&…

IPsec:网络层的加密盾牌与HTTPS的差异解析

​​一、IPsec核心原理​​1. 安全封装结构​┌───────────────┬────────────────┬──────────────────────┐ │ IP头部 │ IPSec头部 │ 加密/认证的载荷 │ │ (路由寻址) │ (AH/ESP) │…

【Python办公】Python如何批量提取PDF中的表格

目录 专栏导读概述主要工具库介绍1. tabula-py2. camelot-py3. pdfplumber4. PyMuPDF (fitz)环境准备安装依赖Java环境配置(tabula-py需要)方法一:使用tabula-py提取表格基础用法高级配置方法二:使用camelot-py提取表格方法三:使用pdfplumber提取表格批量处理多个PDF文件数…

MySQL自定义order by排序规则

数据表create table tb_user (id bigint auto_incrementprimary key,name varchar(16) not null,age int not null,address varchar(128) null );INSERT INTO test.tb_user (id, name, age, address) VALUES (1, 张三, 18, China); INSERT INTO test.tb_…

112套开题答辩行业PPT模版

毕业答辩开题报告&#xff0c;毕业答辩&#xff0c;论文设计PPT&#xff0c;清新论文答辩PPT模版&#xff0c;毕业论文答辩开题报告PPT&#xff0c;答辩演讲通用PPT模版&#xff0c;文艺时尚毕业答辩PPT模版&#xff0c;简约毕业论文答辩PPT模版112套开题答辩行业PPT模版&#…

驱动开发系列61- Vulkan 驱动实现-SPIRV到HW指令的实现过程(2)

本节继续介绍下SPIR-V到LLVM IR的转换过程,重点分析其核心机制和关键转换步骤。我们将从 LLVM 入手,结合实SPIR-V结构逐步转换为符合 LLVM IR 语义的表示方式。 一:详细过程 1. 创建llvm::module llvm::LLVMContext llvmContext; std::unique_ptr<llvm::Mod…

集训Demo2

做一个类似原神圣遗物生成、穿戴、卸下的案例创建项目创建数据库添加圣遗物获取4个数字&#xff0c;对应圣遗物随机的四种属性构造对象添加批量删除圣遗物foreach构造数组转移圣遗物分别在items和character两个库中根据id获取对象&#xff0c;判断唯一id存在哪个数据库中在item…

RedisJSON 技术揭秘`JSON.CLEAR` 一键清空容器、重置数字的“软删除”

一、指令速查 JSON.CLEAR <key> [path]参数说明keyRedis 键名pathJSONPath&#xff08;可选&#xff0c;缺省 $ 根&#xff1b;支持 *、.. 多路径&#xff09;返回值&#xff1a;整数——被清空的数组 / 对象数量 被置零的数值字段数量。已为空或为 0 的字段不会重复统计…

Java单元测试JUnit

文章目录前言一、JUnit描述&#xff08;引入Maven&#xff09;二、基本API注解2.1、Assert类2.2、JUnit注解三、普通单元测试3.1、BeforeClass、AfterClass、Before、After、Test合集测试四、SpringBoot单元测试4.1、SpringBoot集成Junit介绍4.2、实战&#xff1a;SpringBoot项…

HR数字化转型:3大痛点解决方案与效率突破指南

在人力资源部门工作多年&#xff0c;每天面对堆积如山的简历、此起彼伏的员工咨询、错综复杂的薪酬报表……作为HR的你&#xff0c;是否常感到被海量事务性工作淹没&#xff0c;难以喘息&#xff1f;在数字化转型的浪潮下&#xff0c;传统工作方式正遭遇前所未有的挑战。本文将…

如何运用个人IP影响力寻找使命的力量|创客匠人

在知识付费领域&#xff0c;那些能穿越周期的 IP&#xff0c;往往不只是 “卖课机器”&#xff0c;而是以使命为内核的价值传递者。使命为知识变现注入灵魂&#xff0c;让知识产品从 “信息交易” 升华为 “价值共鸣”&#xff0c;这正是个人 IP 实现深度变现与长期影响力的关键…

软件开发中的瀑布式开发与敏捷开发

一、瀑布式开发&#xff08;Waterfall Model&#xff09;核心流程 采用线性、阶段化开发&#xff0c;依次经历需求分析、设计、开发、测试、部署、维护&#xff0c;前一阶段完成后进入下一阶段&#xff0c;如瀑布流水单向推进。 典型阶段&#xff1a;需求固化→架构设计→代码实…

如何卸载SQLServer

1.打开控制面板2.双击&#xff0c;弹出对话框&#xff0c;点击删除3.然后一步一步跟着提示&#xff0c;下一步下一步就好了。4.如果发现没有卸载干净&#xff0c;快捷键winR&#xff0c;输入regedit&#xff0c;进入注册表5.找到计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\…

策略设计模式分析

策略设计模式概述策略模式&#xff08;Strategy Pattern&#xff09;属于行为型设计模式&#xff0c;允许在运行时动态选择算法或行为。它将算法封装成独立的类&#xff0c;使得它们可以相互替换&#xff0c;而不会影响客户端代码。核心组件1. 策略接口&#xff08;Strategy In…

IPM31主板E3300usb键盘鼠标安装成功Sata接口硬盘IDE模式server2003-nt-5.2.3790

IPM31主板E3300usb键盘鼠标安装成功Sata接口硬盘IDE模式server2003-nt-5.2.3790

Docker环境搭建与容器操作全攻略:从入门到实战

一、环境搭建 1.1 基础包安装&#xff08;最小化系统&#xff09; # 备份Yum源配置 mkdir /etc/yum.repos.d/bak mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/bak/ 配置Yum源示例 可以更换为阿里云镜像 cat <<EOF > /etc/yum.repos.d/local.repo [baseos] …

4.2TCP/IP

1、TCP/IP基础&#xff08;重要&#xff09;概要网络协议3要素&#xff1a;语法、语义、时序 osi七层模型&#xff1a;应用层、表示层、会话层、传输层、网络层、数据链路层、物理层tcp四层模型&#xff1a;应用层&#xff08;应用层、表示层、会话层&#xff09;、传输层、int…

Java之Stream其二

文章目录5,Optional5.1,概述5.2,使用5.2.1,创建对象5.2.2,安全消费值5.2.3,获取值5.2.4,安全获取值5.2.5,过滤5.2.6,判断5.2.7,数据转换6,方法引用6.1 推荐用法6.2 基本格式6.3 语法详解(了解)6.3.1 引用类的静态方法6.3.2 引用对象的实例方法6.3.3 引用类的实例方法6.3.4 构造…

一般芯片电气特性中Flash参数达到其最大值的条件是什么?

芯片电气特性中标注的最大值&#xff08;比如 Data Flash 擦除时间的最大值&#xff09;&#xff0c;代表在最恶劣但仍在规格书定义的工作条件范围内的情况下&#xff0c;该参数可能达到的最差值。达到这个最大值通常是由多个最坏情况因素组合造成的。 对于 Data Flash 擦除时间…

python中正则中的split方法、sub方法、finditer方法、compile方法、match对象

正则常见方法梳理 split方法 将一个字符串按照正则表达式匹配结果进行分割,返回结果是列表类型。 pattern:正则表达式的字符串或原生字符串表示string:待匹配字符串maxsplit:最大分割数,剩余部分最为最后一个元素输出flags:正则表达式使用时候的控制标记 re模块的spli…