spring boot统一返回结果

本文介绍了SpringBoot项目中统一的响应结果设计方法,包括定义响应码枚举和创建通用的结果类,用以标准化API返回的数据结构,提高系统的可维护性和易用性。

springboot 同一返回结果

1、响应码枚举

package com.gaojiashun.enums;

public enum AppHttpCodeEnum {

    SUCCESS(200, "操作成功"),
    NEED_LOGIN(401, "需要登录后操作"),
    NO_OPERATOR_AUTH(403, "无权限操作"),
    TOKEN_ILL(404,"token非法"),
    SYSTEM_ERROR(500, "出现错误"),
    USERNAME_EXIST(501, "用户名已经存在"),
    PHOMENUMBER_EXIST(502, "手机号已存在"),
    EMAIL_EXIST(503, "邮箱已存在"),
    REQUEST_USERNAME(504, "必须填写用户名"),
    LOGIN_ERROR(505, "用户名或密码错误");

    int code;
    String msg;

    AppHttpCodeEnum(int code, String errorMessage) {
        this.code = code;
        this.msg = errorMessage;
    }

    public int getCode() {
        return this.code;
    }

    public String getMsg() {
        return this.msg;
    }

}

2、同一结果类

package com.itheima.reggie.common;

import com.itheima.reggie.enums.AppHttpCodeEnum;
import lombok.Data;

import java.util.HashMap;
import java.util.Map;
import java.util.Objects;

@Data
public class Result<T> {
    /**
     * 响应编码
     */
    private Integer code;
    /**
     * 响应信息
     */
    private String msg;
    /**
     * 响应数据
     */
    private T data;

    public Result(Integer code,String msg){
        this.code=code;
        this.msg=msg;
    }

    public Result(Integer code,String msg,T data){
        this.code=code;
        this.msg=msg;
        this.data=data;
    }

    public static Result success(){
        return Result.success(AppHttpCodeEnum.SUCCESS.getCode(),AppHttpCodeEnum.SUCCESS.getMessage());
    }
    public static Result success(int code,String msg){
        Result<Object> result = new Result<>();
        result.setCode(code);
        result.setMsg(msg);
        return result;
    }

    public static Result success(Object data){
        Result<Object> result = new Result<>(AppHttpCodeEnum.SUCCESS.getCode(),AppHttpCodeEnum.SUCCESS.getMessage());
        if (Objects.nonNull(data)){
            result.setData(data);
        }
        return result;
    }

    public static Result error(int code,String msg){
        Result<Object> result = new Result<>(code,msg);
        return result;
    }

    public static Result error(AppHttpCodeEnum appHttpCodeEnum){
        Result<Object> result = new Result<>(appHttpCodeEnum.getCode(), appHttpCodeEnum.getMessage());
        return result;
    }
}

Spring Boot实现统一返回可通过以下方式: - **使用`@ControllerAdvice + ResponseBodyAdvice`**:`@ControllerAdvice`是Spring框架提供的用于全局处理控制器的增强器注解,通过该注解的类,能将增强逻辑应用到所有`@Controller`注解的控制器中。`ResponseBodyAdvice`是用于处理响应体的接口,实现此接口,可在`Controller`方法返回前后对响应体进行处理。具体实现需创建统一响应类 [^3]。 - **运用AOP思维**:统一数据返回运用了AOP(对某一类事情的集中处理)的思维,在前后端数据交互时,让后端数据进行统一的打包封装,返回给前端,便于前后端的数据处理 [^4]。 此外,可通过完成定义统一结果返回类、配置全局异常处理器等步骤,实现统一结果返回和异常处理,也能达到统一返回的目的,且这样不仅节省开发时间,还能提升项目的健壮性和用户体验 [^1][^2]。 ```java import org.springframework.core.MethodParameter; import org.springframework.http.MediaType; import org.springframework.http.server.ServerHttpRequest; import org.springframework.http.server.ServerHttpResponse; import org.springframework.web.bind.annotation.ControllerAdvice; import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice; // 定义统一响应类 class UnifiedResponse { private int code; private String message; private Object data; public UnifiedResponse(int code, String message, Object data) { this.code = code; this.message = message; this.data = data; } // Getters and setters public int getCode() { return code; } public void setCode(int code) { this.code = code; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } public Object getData() { return data; } public void setData(Object data) { this.data = data; } } // 使用 @ControllerAdvice 和 ResponseBodyAdvice 实现统一返回 @ControllerAdvice public class CustomResponseBodyAdvice implements ResponseBodyAdvice<Object> { @Override public boolean supports(MethodParameter returnType, Class converterType) { return true; } @Override public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) { return new UnifiedResponse(200, "Success", body); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值