news 2026/6/16 12:23:35

简单业务异常类

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
简单业务异常类

一、最简版本(适合新手)

import lombok.Getter; /** * 业务异常 - 最简单版本 */ @Getter public class BusinessException extends RuntimeException { private final Integer code; // 错误码 // 构造方法1:指定错误码和消息 public BusinessException(Integer code, String message) { super(message); this.code = code; } // 构造方法2:只传消息,默认500错误码 public BusinessException(String message) { this(500, message); } }

二、稍微丰富版本(推荐)

import lombok.Getter; /** * 业务异常 - 常用版本 */ @Getter public class BusinessException extends RuntimeException { private final Integer code; // 常用状态码定义 public static final Integer BAD_REQUEST = 400; // 请求参数错误 public static final Integer UNAUTHORIZED = 401; // 未授权 public static final Integer FORBIDDEN = 403; // 禁止访问 public static final Integer NOT_FOUND = 404; // 资源不存在 // 常用构造方法 public BusinessException(Integer code, String message) { super(message); this.code = code; } public BusinessException(String message) { this(500, message); } // 快速创建方法(静态工厂方法) public static BusinessException badRequest(String message) { return new BusinessException(BAD_REQUEST, message); } public static BusinessException notFound(String resourceName) { return new BusinessException(NOT_FOUND, resourceName + "不存在"); } public static BusinessException forbidden() { return new BusinessException(FORBIDDEN, "无权限访问"); } }

三、配合枚举使用

// 1. 先定义错误枚举 @Getter public enum ErrorCode { SUCCESS(200, "成功"), PARAM_ERROR(400, "参数错误"), UNAUTHORIZED(401, "未登录"), FORBIDDEN(403, "无权限"), NOT_FOUND(404, "资源不存在"), USER_NOT_FOUND(40401, "用户不存在"), SYSTEM_ERROR(500, "系统错误"); private final Integer code; private final String message; ErrorCode(Integer code, String message) { this.code = code; this.message = message; } } // 2. 修改异常类 @Getter public class BusinessException extends RuntimeException { private final Integer code; // 使用枚举构造 public BusinessException(ErrorCode errorCode) { super(errorCode.getMessage()); this.code = errorCode.getCode(); } // 自定义消息 public BusinessException(ErrorCode errorCode, String customMessage) { super(customMessage); this.code = errorCode.getCode(); } }

四、实际使用例子

@Service public class UserService { public User getUserById(Long id) { User user = userRepository.findById(id); // 情况1:直接抛异常 if (user == null) { throw new BusinessException(404, "用户不存在"); } // 情况2:使用快速方法 if (user.getStatus() == 0) { throw BusinessException.forbidden(); } // 情况3:使用枚举 if (user.getBalance() < 0) { throw new BusinessException(ErrorCode.PARAM_ERROR, "余额不能为负"); } return user; } public void transfer(Long fromId, Long toId, BigDecimal amount) { // 使用连串校验 User fromUser = userRepository.findById(fromId) .orElseThrow(() -> new BusinessException(ErrorCode.USER_NOT_FOUND)); if (fromUser.getBalance().compareTo(amount) < 0) { throw new BusinessException(400, "余额不足"); } // 业务逻辑... } }

五、全局异常处理

@RestControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(BusinessException.class) public Result<?> handleBusinessException(BusinessException e) { // 统一返回格式 return Result.error(e.getCode(), e.getMessage()); } @ExceptionHandler(Exception.class) public Result<?> handleOtherException(Exception e) { // 其他异常 log.error("系统异常", e); return Result.error(500, "系统异常"); } } // 统一返回结果 @Data class Result<T> { private Integer code; private String message; private T data; public static <T> Result<T> success(T data) { Result<T> result = new Result<>(); result.code = 200; result.message = "成功"; result.data = data; return result; } public static <T> Result<T> error(Integer code, String message) { Result<T> result = new Result<>(); result.code = code; result.message = message; return result; } }

六、总结要点

最简写法(记住这个就行):

public class BusinessException extends RuntimeException { private Integer code; public BusinessException(Integer code, String message) { super(message); this.code = code; } }

使用三部曲:

  1. 定义异常类(上面代码)

  2. 在需要的地方抛出

    if (条件不满足) { throw new BusinessException(400, "错误信息"); }
  3. 全局处理(返回统一格式)

记住几个常用错误码:

  • 400:参数错误

  • 401:未登录

  • 403:无权限

  • 404:不存在

  • 500:系统错误

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/14 23:00:00

CinoLib:统一多面体网格处理终极指南

CinoLib&#xff1a;统一多面体网格处理终极指南 【免费下载链接】cinolib A generic programming header only C library for processing polygonal and polyhedral meshes 项目地址: https://gitcode.com/gh_mirrors/ci/cinolib CinoLib是一个功能强大的C编程库&#…

作者头像 李华
网站建设 2026/6/15 3:12:34

企业微信客户联系API中 添加客户 与 发送欢迎语 的异步处理优化

一、引言 (Introduction) 1.1 背景&#xff1a; 客户联系 API 是企业微信连接外部客户的核心功能。在批量拉新、推广活动等高并发场景下&#xff0c;同步处理“添加客户”和“发送欢迎语”的流程容易造成性能瓶颈和用户体验下降。 1.2 目的&#xff1a; 分析同步处理的痛点&am…

作者头像 李华
网站建设 2026/6/15 4:03:49

Access Token 刷新与管理:高并发场景下的最优策略与防并发锁实现

一、引言 (Introduction) 1.1 Access Token 的重要性&#xff1a; 它是企业微信 API 调用的唯一凭证&#xff0c;其有效性和获取效率是系统高可用的基石。 1.2 高并发场景下的挑战&#xff1a; 过期与刷新竞争&#xff1a; 在 Token 即将过期时&#xff0c;大量并发请求可能同…

作者头像 李华
网站建设 2026/6/10 1:48:08

Python基础二:数据类型与数据结构(上)

一、前提 数据类型与数据结构,这两个词在计算机领域经常出现。这其实是一种从问题域到计算机实现的映射。因为从广义上来讲,我们编写程序是为了处理数据(比如学生成绩、商品信息等)。为了高效处理这些数据,我们需要给它们进行分门别类(类型)、和设计不同的组织形式(结…

作者头像 李华
网站建设 2026/6/13 16:18:17

3、Kali Linux入门指南:基础操作与命令详解

Kali Linux入门指南:基础操作与命令详解 1. 启动与登录Kali 启动Kali后,会看到登录界面。使用root账户(用户名:root,默认密码:toor)进行登录。登录成功后,你将进入Kali桌面。 2. 终端与文件系统基础 2.1 终端操作 使用Kali的第一步是打开终端,它是命令行界面。在K…

作者头像 李华