SpringBoot 统一功能处理

1. 拦截器

1.1 拦截器快速入门

拦截器用于拦截用户请求,执行在目标方法前后,执行了一段代码

拦截器使用:

  • 定义拦截器
  • 注册并配置拦截器

自定义拦截器,实现HandlerInterceptor接口,并重写所有方法

复制代码
//拦截器
@Slf4j
public class LoginInterceptor  implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        log.info("目标方法执行前执行");
        //true=>放行  false=>拦截
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        log.info("目标方法执行后执行");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        log.info("页面渲染后执行");
    }
}

配置拦截器,实现WebMvcConfigurer 接口 ,并重写addInterceptors方法

复制代码
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Autowired
    private LoginInterceptor loginInterceptor;//注入上面设置的拦截器


//重写方法
@Override
public void addInterceptors(InterceptorRegistry registry) {
    registry.addInterceptor(loginInterceptor)
            .addPathPatterns("/**")
            .excludePathPatterns("/static/css/**", "/static/js/**", "/static/pic/**", "/user/login");
}
复制代码
}

1.2 拦截器详解

1.2.1 拦截路径

  • /**:匹配所有路径
  • /admin/*:匹配/admin下的单级路径
  • /admin/**:匹配/admin下的多级路径

1.2.2 拦截器执行流程

客户端请求

preHandle()方法

↓ 返回true

处理器方法执行

postHandle()方法

视图渲染

afterCompletion()方法

2. 统一数据返回格式

创建统一响应体类:

复制代码
package com.example.springbookdemo.entity;

import com.example.springbookdemo.enums.ResultCodeEnum;
import lombok.Data;

@Data
public class Result<T> {
    private int code;//-1=>未登录   -2=>参数错误  200=>正常 -100=>异常
    private String message;
    private T data;

    public static <T> Result<T> unLogin(){
        Result<T> result=new Result<T>();
        result.setCode(ResultCodeEnum.UNLOGIN.getCode());
        result.setMessage(ResultCodeEnum.UNLOGIN.getMessage());
        return result;
    }

    public static <T> Result<T> success(T data){
        Result<T> result=new Result<T>();
        result.setCode(ResultCodeEnum.SUCCESS.getCode());
        result.setMessage("");
        result.setData(data);
        return result;
    }

    public static <T> Result<T> pararmError (){
        Result<T> result=new Result<T>();
        result.setCode(ResultCodeEnum.PARARM_ERROR.getCode());
        result.setMessage(ResultCodeEnum.PARARM_ERROR.getMessage());
        return result;
    }

    public static <T> Result<T> pararmError (String message){
        Result<T> result=new Result<T>();
        result.setCode(ResultCodeEnum.PARARM_ERROR.getCode());
        result.setMessage(message);
        return result;
    }

    public static <T> Result<T> Fail (String message){
        Result<T> result=new Result<T>();
        result.setCode(ResultCodeEnum.FAIL.getCode());
        result.setMessage(message);
        return result;
    }
}

编写一个类实现ResponseBodyAdvice接口,并重写两个方法,添加 @ControllerAdvice

复制代码
@ControllerAdvice
public class ResponseAdvice implements ResponseBodyAdvice {

    @Override
    public boolean supports(MethodParameter returnType, Class converterType) {
        //该方法用于判断是否对结果进行处理
        //true为处理,false为不处理
        return true;
    }


    @Autowired
    ObjectMapper objectMapper;//便于后续对String转JSon操作
    @SneakyThrows//相当于使用try/catch

//上一个方法返回true则执行该方法
    @Override
    public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, Class selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) {

        //该方法用于处理结果
        //参数中的body代表结果
        if(body instanceof Result){
            return body;
        }
        //统一结果返回,需要额外对String类型进行处理
        if(body instanceof String){
            return objectMapper.writeValueAsString(Result.success(body));
            //返回JSON
        }
        return Result.success(body);
    }
}

3. 统一异常处理

用@ControllerAdvice+@ExceptionHandler实现

复制代码
//统一异常处理
@ControllerAdvice
@ResponseBody
public class ErrorAdvice {
    @ExceptionHandler
    public Object handler(Exception e){
        return Result.Fail(e.getMessage());
    }
}
相关推荐
RulerMike4 分钟前
three 实现简单机械臂逆运动
前端·ai编程·three.js
darkb1rd5 分钟前
从“会聊天”到“会搭页面”:一次 TinyEngine + MCP 的前端智能化实战思路
前端
爱喝白开水a10 分钟前
春节后普通程序员如何“丝滑”跨行AI:不啃算法,也能拿走AI
java·人工智能·算法·spring·ai·前端框架·大模型
毕设源码-朱学姐14 分钟前
【开题答辩全过程】以 基于Java的运动场地预约系统为例,包含答辩的问题和答案
java·开发语言
蜜獾云21 分钟前
Spring Cloud Hystrix 详细示-元一软件
java·spring cloud·hystrix
烛之武22 分钟前
SpringBoot 实战篇
java·spring boot·后端
社恐的下水道蟑螂22 分钟前
从奶茶店彻底搞懂 SSR!从零到拿捏服务端渲染,看完面试吹牛逼不卡壳
前端·react.js·性能优化
lclcooky23 分钟前
Spring 核心技术解析【纯干货版】- XII:Spring 数据访问模块 Spring-R2dbc 模块精讲
java·后端·spring
李白的粉24 分钟前
基于springboot的相亲网站
java·spring boot·毕业设计·课程设计·相亲网站
EnCi Zheng27 分钟前
M1-如何转换为HTML
前端·html