11)SpringBoot 统一响应格式

1 要求

  每个请求成功后,后台返回的响应格式都是一致的,例如:

    

 

2 创建一个视图模型

  该模型用于格式化响应数据

 

package cn.xiangxu.springboottest.model.dataViewModel;

import lombok.Data;

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

 

 

3 创建一个视图模型工具类

  该工具类根据传入的参数来实例化视图模型类

  

 

 

package cn.xiangxu.springboottest.utils;

import cn.xiangxu.springboottest.model.dataViewModel.ResultViewModel;

/**
 * 响应数据封装类
 */
public class ResultViewModelUtil {
    /**
     * 请求成功方法01
     * @param object 响应数据
     * @return 视图模型实例
     */
    public static ResultViewModel success(Object object) {
        ResultViewModel resultViewModel = new ResultViewModel();
        resultViewModel.setCode(0);
        resultViewModel.setMessage("请求成功");
        resultViewModel.setData(object);
        return resultViewModel;
    }

    /**
     * 请求成功方法02
     * @return 视图模型实例
     */
    public static ResultViewModel success() {
        return success(null);
    }

    /**
     * 请求失败方法01(捕获到的已知异常)
     * @param code 异常编号
     * @param message 异常信息
     * @return 视图模型实例
     */
    public static ResultViewModel error(Integer code, String message) {
        ResultViewModel resultViewModel = new ResultViewModel();
        resultViewModel.setCode(code);
        resultViewModel.setMessage(message);
        resultViewModel.setData(null);
        return resultViewModel;
    }

    /**
     * 请求失败方法02(系统异常)
     * @return 视图模型实例
     */
    public static ResultViewModel error() {
        ResultViewModel resultViewModel = new ResultViewModel();
        resultViewModel.setCode(-1);
        resultViewModel.setMessage("系统异常");
        resultViewModel.setData("系统维护中...");
        return resultViewModel;
    }
}

 

 

4 利用视图模型工具类向前台返回格式化的JSON数据

  

 

 

package cn.xiangxu.springboottest.controller;

import cn.xiangxu.springboottest.model.dataViewModel.ResultViewModel;
import cn.xiangxu.springboottest.service.GirlService;
import cn.xiangxu.springboottest.utils.ResultViewModelUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@RestController
@RequestMapping(value = "/girl")
@Slf4j
public class GirlController {

    @Resource(name = "girlService")
    private GirlService girlService;

    @GetMapping
    public ResultViewModel test() {
        log.info("hello boy");
        return ResultViewModelUtil.success("响应数据");
//        return ResultViewModelUtil.success(girlService.findAllGirl());
    }

}

原文链接https://www.cnblogs.com/NeverCtrl-C/p/8177492.html

 

 

关注公众号,将会有更多精彩每天送达:

公众号内有精彩内容,可以提现

                                                       

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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); } } ``` 通过以上步骤,我们就可以在每次请求完成后,在控制台中打印出响应时间了。这样可以方便我们对应用的性能进行监控和优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值