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());
    }
}
相关推荐
LinXunFeng5 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg8 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭9 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒9 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭9 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
小bo波9 小时前
从"任意文件复制"深挖Java I/O:字符流与字节流的本质抉择
java·nio·io流·后端开发·文件复制
Hyyy10 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
用户35218024547510 小时前
🎆从 Prompt 到 Skill:让 Spring AI Agent 学会"装新技能"
人工智能·spring boot·ai编程
Gatlin11 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic11 小时前
本地通知(Local Notifications)学习笔记
前端