Java响应Response结果集Result封装规范,需要哪些类,及其所属包规范(详细介绍)

1.ResponseVO:专门用于响应返回给前端的

一般位于entity包下面

@Data
public class ResponseVO<T> {
    private Integer code;
    private String message;
    private T data;

    public ResponseVO(ResultEnum resultEnum) {
        this.code = resultEnum.getCode();
        this.message = resultEnum.getMessage();
    }
    public ResponseVO(Integer code, String message) {
        this.code = code;
        this.message = message;
    }
    public ResponseVO(Integer code, String message, T data) {
        this.code = code;
        this.message = message;
        this.data = data;
    }
    public ResponseVO(T data) {
        this.data = data;
    }
}


2.ResponseEnum :返回的枚举类型,包括状态码和响应信息

一般位于constant.enums包下面

@AllArgsConstructor
@Getter
public enum ResponseEnum {
    SUCCESS(200,"成功"),
    FAILURE(500,"服务器错误"),
    FILE_SIZE_ERROR(500, "文件大小异常");
    private Integer code;
    private String message;
}

3.ResultUtil:里面封装的静态方法,主要用于返回ResponseVO

一般位于utils包下面,
注意:成功一般不用传入code,默认为ResponseEnum.SUCCESS.getCode,即200,
失败一般不需要传入data,只需要告诉失败的状态码code和失败的错误信息message即可

 

/**
 * 结果工具类
 *
 * @author daz
 * @date 2024/6/10
 */
public class ResultUtil {
    /**
     * 成功:返回值结果不包含数据
     */
    public static ResponseVO success() {
        return new ResponseVO(ResponseEnum.SUCCESS);
    }

    /**
     * 成功:返回结果包含数据
     */
    public static <T> ResponseVO<T> success(T data) {
        return new ResponseVO(data);
    }

    /**
     * 成功:返回结果不包含数据,自定义成功消息
     */
    public static ResponseVO success(String message) {
        return new ResponseVO(ResponseEnum.SUCCESS.getCode(), message);
    }

    /**
     * 成功:返回结果包含数据,自定义成功的消息
     */
    public static <T> ResponseVO<T> success(String message, T data) {
        return new ResponseVO(ResponseEnum.SUCCESS.getCode(), message, data);
    }

    /**
     * 失败:默认是500,服务器错误
     */
    public static ResponseVO fail() {
        return new ResponseVO(ResponseEnum.FAILURE);
    }

    /**
     * 失败:传入定义的失败枚举
     */
    public static ResponseVO fail(ResponseEnum resultEnum) {
        return new ResponseVO(resultEnum);
    }

    /**
     * 失败:自定义失败的消息
     */
    public static ResponseVO fail(String message) {
        return new ResponseVO(ResponseEnum.FAILURE.getCode(), message);
    }

    /**
     * 失败:自定义失败码和消息
     */
    public static ResponseVO fail(Integer code, String message) {
        return new ResponseVO(code, message);
    }
}

4.测试及结果

    public static void main(String[] args) {
        Student student = new Student(1, "zhangsan", 20);
        //成功测试
        System.out.println(ResultUtil.success());
        System.out.println(ResultUtil.success("修改成功"));
        System.out.println(ResultUtil.success(student));
        System.out.println(ResultUtil.success("数据获取成功",student));
        //失败测试
        System.out.println(ResultUtil.fail());
        System.out.println(ResultUtil.fail("token已过期"));
        System.out.println(ResultUtil.fail(ResponseEnum.FILE_SIZE_ERROR));
        System.out.println(ResultUtil.fail(404,"错误请求"));
    }


 

5.注解解释:

@Data:默认包含setter和getter方法,但是不提供有参构造
@AllArgsConstructor:有参构造
@Getter:提供getter方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值