三、SpringBoot统一响应结果

在实际开发中,后端工作者会将数据返回给前端,但是咱们不能随意的去返回后端数据,这时候前后端的工作人员都会读到的开发者文档就起到啦作用。

接上述,我们为上一个简单的增删改查统一响应结果

一、定义统一响应结果类

1. 我们在entity包下新建一个Result类
import lombok.AllArgsConstructor;
import lombok.NoArgsConstructor;

// 统一响应结果的数据
@NoArgsConstructor
@AllArgsConstructor

public class Result<T> {
    private Integer code; // 业务的状态码 0-成功 1-失败
    private String message; // 提示信息
    private T data; // 响应结果 泛型T

    //快速返回操作成功响应结果(带响应数据)
    public static <E> Result<E> success(E data) {
        return new Result<>(0, "操作成功", data);
    }

    //快速返回操作成功响应结果
    public static Result success() {
        return new Result(0, "操作成功", null);
    }

    public static Result error(String message) {
        return new Result(1, message, null);
    }

    /**
     * 获取
     * @return code
     */
    public Integer getCode() {
        return code;
    }

    /**
     * 设置
     * @param code
     */
    public void setCode(Integer code) {
        this.code = code;
    }

    /**
     * 获取
     * @return message
     */
    public String getMessage() {
        return message;
    }

    /**
     * 设置
     * @param message
     */
    public void setMessage(String message) {
        this.message = message;
    }

    /**
     * 获取
     * @return data
     */
    public T getData() {
        return data;
    }

    /**
     * 设置
     * @param data
     */
    public void setData(T data) {
        this.data = data;
    }

    public String toString() {
        return "Result{code = " + code + ", message = " + message + ", data = " + data + "}";
    }
}

二、使用统一响应结果类

1. 在UserController中改变增加接口,为其添加返回值类型(其他地方无需改变)

三、 测试

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Spring Boot中,我们可以使用拦截器(Interceptor)来实现统一打印响应时间的功能。 首先,我们需要创建一个实现了HandlerInterceptor接口的拦截器类,该接口包含了个方法:preHandle、postHandle和afterCompletion。我们可以在preHandle方法中获取请求开始的时间,然后在afterCompletion方法中计算响应时间并打印出来。 以下是一个简单的示例代码: ```java import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Component; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; @Component public class ResponseTimeInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) { request.setAttribute("startTime", System.currentTimeMillis()); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) { // 什么都不做 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { long startTime = (long) request.getAttribute("startTime"); long endTime = System.currentTimeMillis(); long responseTime = endTime - startTime; System.out.println("响应时间: " + responseTime + "毫秒"); } } ``` 接下来,我们需要在Spring Boot应用的配置类中注册该拦截器: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class WebConfig implements WebMvcConfigurer { @Autowired private ResponseTimeInterceptor responseTimeInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(responseTimeInterceptor); } } ``` 通过以上步骤,我们就可以在每次请求完成后,在控制台中打印出响应时间了。这样可以方便我们对应用的性能进行监控和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值