Web层统一实体规范封装

2024-08-24 21:12
文章标签 封装 web 统一 规范 实体

本文主要是介绍Web层统一实体规范封装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.统一响应封装
        • 1.目录结构
        • 2.ResultCode.java 定义http的响应状态码
        • 3.ResultMessage.java 定义http响应的message
        • 4.Result.java 通用响应封装类
    • 2.统一异常处理封装(策略模式)
        • 1.目录结构
        • 2.response (也可以使用上面的方式,这里故意写了枚举类的方式)
          • 1.RespBeanEnum.java 响应枚举类
          • 2.Result.java 通用响应封装类
        • 3.strategys 策略模式
          • 1.ExceptionStrategy.java 策略接口核心:一个标识,一个处理逻辑的方法
          • 2.BindExceptionStrategy.java
          • 3.CustomExceptionStrategy.java
        • 4.GlobalExceptionHandler.java 全局异常处理
        • 5.CustomException.java 自定义异常

1.统一响应封装

1.目录结构

CleanShot 2024-07-10 at 18.28.19@2x

2.ResultCode.java 定义http的响应状态码
package com.sunxiansheng;/*** Description: 定义http的响应状态码* @Author sun* @Create 2024/7/10 16:39* @Version 1.0*/
public class ResultCode {public static final Integer SUCCESS = 200;public static final Integer ERROR = 500;public static final Integer PARAMNOTEXIST = 499;}
3.ResultMessage.java 定义http响应的message
package com.sunxiansheng;/*** Description: 定义http响应的message* @Author sun* @Create 2024/7/10 16:42* @Version 1.0*/
public class ResultMessage {public static final String SUCCESS = "成功";public static final String ERROR = "失败";}
4.Result.java 通用响应封装类
package com.sunxiansheng;import lombok.Data;
import java.io.Serializable;/*** Description: 通用响应封装类* @Author sun* @Create 2024/7/10* @Version 1.0*/
@Data
public class Result<T> implements Serializable {private static final long serialVersionUID = 1L;// 是否成功private boolean success;// 响应代码private int code;// 响应消息private String message;// 响应数据private T data;// 私有构造器,防止外部直接创建private Result() {}// 使用内部建造者类进行对象构建public static class Builder<T> {private boolean success;private int code;private String message;private T data;// ============================== 链式调用设置建造者对象 ==============================public Builder<T> success(boolean success) {this.success = success;return this;}public Builder<T> code(int code) {this.code = code;return this;}public Builder<T> message(String message) {this.message = message;return this;}public Builder<T> data(T data) {this.data = data;return this;}// ============================== 链式调用设置建造者对象 ==============================// ============================== 构建Result对象 ==============================public Result<T> build() {Result<T> result = new Result<>();result.success = this.success;result.code = this.code;result.message = this.message;result.data = this.data;return result;}// ============================== 构建Result对象 ==============================}// ============================== 快捷方法 ==============================public static <T> Result<T> ok() {return new Builder<T>().success(true).code(ResultCode.SUCCESS).message(ResultMessage.SUCCESS).build();}public static <T> Result<T> ok(T data) {return new Builder<T>().success(true).code(ResultCode.SUCCESS).message(ResultMessage.SUCCESS).data(data).build();}public static <T> Result<T> ok(T data, String message) {return new Builder<T>().success(true).code(ResultCode.SUCCESS).message(message).data(data).build();}public static <T> Result<T> fail() {return new Builder<T>().success(false).code(ResultCode.ERROR).message(ResultMessage.ERROR).build();}public static <T> Result<T> fail(String message) {return new Builder<T>().success(false).code(ResultCode.ERROR).message(message).build();}public static <T> Result<T> fail(int code, String message) {return new Builder<T>().success(false).code(code).message(message).build();}// ============================== 快捷方法 ==============================}

2.统一异常处理封装(策略模式)

1.目录结构

CleanShot 2024-07-11 at 18.53.38@2x

2.response (也可以使用上面的方式,这里故意写了枚举类的方式)
1.RespBeanEnum.java 响应枚举类
package com.sunxiansheng.exception.response;import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.ToString;/*** Description: 响应枚举类** @Author sun* @Create 2024/5/5 15:15* @Version 1.0*/@Getter
@AllArgsConstructor
@ToString
public enum RespBeanEnum {// 通用SUCCESS(200, "成功"),ERROR(500, "失败"),//登录模块LOGIN_ERROR(500210, "用户名或者密码错误"),MOBILE_ERROR(500211, "手机号码格式不正确"),BING_ERROR(500212, "参数绑定异常"),MOBILE_NOT_EXIST(500213, "手机号码不存在"),PASSWORD_UPDATE_FAIL(500214, "更新密码失败"),;//其他模块。。。// 响应码和响应信息private final Integer code;private final String message;/*** 根据响应码返回相应的枚举对象* @param code 响应码* @return 对应的枚举对象,如果没有找到则返回 null*/public static RespBeanEnum getByCode(Integer code) {for (RespBeanEnum status : values()) {if (status.getCode().equals(code)) {return status;}}return null;  // 没有找到对应的code时,返回null或者可以选择抛出一个异常}}
2.Result.java 通用响应封装类
package com.sunxiansheng.exception.response;import lombok.Data;import java.io.Serializable;/*** Description: 通用响应封装类,通过枚举来获取code和message* @Author sun* @Create 2024/7/10* @Version 1.0*/
@Data
public class Result<T> implements Serializable {private static final long serialVersionUID = 1L;// 是否成功private boolean success;// 响应代码private int code;// 响应消息private String message;// 响应数据private T data;// 私有构造器,防止外部直接创建private Result() {}// 使用内部建造者类进行对象构建public static class Builder<T> {private boolean success;private int code;private String message;private T data;// ============================== 链式调用设置建造者对象 ==============================public Builder<T> success(boolean success) {this.success = success;return this;}public Builder<T> code(int code) {this.code = code;return this;}public Builder<T> message(String message) {this.message = message;return this;}public Builder<T> data(T data) {this.data = data;return this;}// ============================== 链式调用设置建造者对象 ==============================// ============================== 构建Result对象 ==============================public Result<T> build() {Result<T> result = new Result<>();result.success = this.success;result.code = this.code;result.message = this.message;result.data = this.data;return result;}// ============================== 构建Result对象 ==============================}// ============================== 快捷方法 ==============================public static <T> Result<T> ok() {return new Builder<T>().success(true).code(RespBeanEnum.SUCCESS.getCode()).message(RespBeanEnum.SUCCESS.getMessage()).build();}public static <T> Result<T> ok(T data) {return new Builder<T>().success(true).code(RespBeanEnum.SUCCESS.getCode()).message(RespBeanEnum.SUCCESS.getMessage()).data(data).build();}public static <T> Result<T> ok(T data, String message) {return new Builder<T>().success(true).code(RespBeanEnum.SUCCESS.getCode()).message(message).data(data).build();}public static <T> Result<T> fail() {return new Builder<T>().success(false).code(RespBeanEnum.ERROR.getCode()).message(RespBeanEnum.ERROR.getMessage()).build();}public static <T> Result<T> fail(String message) {return new Builder<T>().success(false).code(RespBeanEnum.ERROR.getCode()).message(message).build();}public static <T> Result<T> fail(int code, String message) {return new Builder<T>().success(false).code(code).message(message).build();}public static <T> Result<T> fail(RespBeanEnum respBeanEnum) {return new Builder<T>().success(false).code(respBeanEnum.getCode()).message(respBeanEnum.getMessage()).build();}// ============================== 快捷方法 ==============================}
3.strategys 策略模式
1.ExceptionStrategy.java 策略接口核心:一个标识,一个处理逻辑的方法
package com.sunxiansheng.exception.strategys;import com.sunxiansheng.exception.response.Result;/*** Description: 处理异常的策略接口* @Author sun* @Create 2024/7/11 18:08* @Version 1.0*/
public interface ExceptionStrategy {/*** 标识自己是处理什么类型异常的策略* @param e* @return*/boolean supports(Exception e);/*** 具体处理异常的策略* @param e* @return*/Result handleException(Exception e);}
2.BindExceptionStrategy.java
package com.sunxiansheng.exception.strategys;
// 注意这里引入的包
import com.sunxiansheng.exception.response.RespBeanEnum;
import com.sunxiansheng.exception.response.Result;
import org.springframework.stereotype.Component;
import org.springframework.validation.BindException;
/*** Description: 参数绑定异常的策略* @Author sun* @Create 2024/7/11 18:14* @Version 1.0*/
@Component
public class BindExceptionStrategy implements ExceptionStrategy {@Overridepublic boolean supports(Exception e) {return e instanceof BindException;}@Overridepublic Result handleException(Exception e) {BindException ex = (BindException) e;String message = "参数校验异常:" + ex.getBindingResult().getAllErrors().get(0).getDefaultMessage();return Result.fail(RespBeanEnum.BING_ERROR.getCode(), message);}}
3.CustomExceptionStrategy.java
package com.sunxiansheng.exception.strategys;import com.sunxiansheng.exception.CustomException;
import com.sunxiansheng.exception.response.Result;
import org.springframework.stereotype.Component;/*** Description: 自定义异常具体策略* @Author sun* @Create 2024/7/11 18:09* @Version 1.0*/
@Component
public class CustomExceptionStrategy implements ExceptionStrategy{@Overridepublic boolean supports(Exception e) {// 如果传进来的时自定义异常的对象,就返回truereturn e instanceof CustomException;}@Overridepublic Result handleException(Exception e) {// 转换为自定义异常CustomException ex = (CustomException) e;// 根据自定义异常的枚举,构建responsereturn Result.fail(ex.getRespBeanEnum());}}
4.GlobalExceptionHandler.java 全局异常处理
package com.sunxiansheng.exception;import com.sunxiansheng.exception.response.RespBeanEnum;
import com.sunxiansheng.exception.response.Result;
import com.sunxiansheng.exception.strategys.ExceptionStrategy;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RestControllerAdvice;import java.util.List;/*** Description: 全局异常处理器** @Author sun* @Create 2024/5/6 15:16* @Version 1.0*/
@RestControllerAdvice
@Slf4j
public class GlobalExceptionHandler {// 将所有的策略都注入进来private final List<ExceptionStrategy> strategies;@Autowired // 可以省略,只有一个构造器,会默认使用这个构造器注入public GlobalExceptionHandler(List<ExceptionStrategy> strategies) {this.strategies = strategies;}/*** 根据不同的异常类型,决定不同的策略* @param e* @return*/@ExceptionHandler(Exception.class)public Result exceptionHandler(Exception e) {log.error("Exception caught: ", e);for (ExceptionStrategy strategy : strategies) {if (strategy.supports(e)) {return strategy.handleException(e);}}return Result.fail(RespBeanEnum.ERROR);}}
5.CustomException.java 自定义异常
package com.sunxiansheng.exception;import com.sunxiansheng.exception.response.RespBeanEnum;
import lombok.Data;
import lombok.NoArgsConstructor;/*** Description: 自定义异常类,具有响应枚举的属性,并允许传递自定义的消息。** @Author sun* @Create 2024/5/6 15:15* @Version 1.1*/
@Data
@NoArgsConstructor
public class CustomException extends RuntimeException {private RespBeanEnum respBeanEnum;private String customMessage;/*** 如果只传入枚举,那么使用枚举的信息,作为异常信息** @param respBeanEnum*/public CustomException(RespBeanEnum respBeanEnum) {super(respBeanEnum != null ? respBeanEnum.getMessage() : null);this.respBeanEnum = respBeanEnum;}/*** 如果传入枚举和自定义消息,那么使用自定义消息,作为异常信息** @param respBeanEnum* @param customMessage*/public CustomException(RespBeanEnum respBeanEnum, String customMessage) {super(customMessage != null ? customMessage : (respBeanEnum != null ? respBeanEnum.getMessage() : null));this.respBeanEnum = respBeanEnum;this.customMessage = customMessage;}@Overridepublic String getMessage() {if (customMessage != null) {return customMessage;}return respBeanEnum != null ? respBeanEnum.getMessage() : super.getMessage();}@Overridepublic String toString() {return "CustomException{" +"respBeanEnum=" + (respBeanEnum != null ? respBeanEnum.toString() : "null") +", customMessage='" + customMessage + '\'' +'}';}
}

这篇关于Web层统一实体规范封装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

Pytorch微调BERT实现命名实体识别

《Pytorch微调BERT实现命名实体识别》命名实体识别(NER)是自然语言处理(NLP)中的一项关键任务,它涉及识别和分类文本中的关键实体,BERT是一种强大的语言表示模型,在各种NLP任务中显著... 目录环境准备加载预训练BERT模型准备数据集标记与对齐微调 BERT最后总结环境准备在继续之前,确

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

通过Python脚本批量复制并规范命名视频文件

《通过Python脚本批量复制并规范命名视频文件》本文介绍了如何通过Python脚本批量复制并规范命名视频文件,实现自动补齐数字编号、保留原始文件、智能识别有效文件等功能,听过代码示例介绍的非常详细,... 目录一、问题场景:杂乱的视频文件名二、完整解决方案三、关键技术解析1. 智能路径处理2. 精准文件名

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re