SpringBoot中的拦截器

SpringBoot中的拦截器

Filter

典型场景 全局鉴权/接口耗时统计

java 复制代码
@WebFilter("/*") 
public class CostFilter implements Filter {
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) {
        long start = System.currentTimeMillis();
        chain.doFilter(req, res); // 放行江湖令箭
        System.out.println("接口耗时:"+(System.currentTimeMillis()-start)+"ms");
    }
}

HandlerInterceptor

典型场景 接口权限验证/请求参数自动装填

java 复制代码
public class AuthInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        String token = request.getHeader("X-Token");
        if(!"vip666".equals(token)){
            response.setStatus(403);
            return false; 
        }
        return true;
    }
}

@Configuration
publicclass WebMvcConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new AuthInterceptor())
                .addPathPatterns("/api/**")
                .excludePathPatterns("/api/login");
    }
}

AOP拦截

典型场景 服务层方法缓存/事务管理

java 复制代码
@Aspect
@Component
public class CacheAspect {
    @Around("@annotation(com.example.anno.Cacheable)")
    public Object aroundCache(ProceedingJoinPoint jp) {
        String cacheKey = buildKey(jp);
        Object cacheVal = redisTemplate.opsForValue().get(cacheKey);
        if(cacheVal != null) return cacheVal;
        
        Object result = jp.proceed();
        redisTemplate.opsForValue().set(cacheKey, result, 5, TimeUnit.MINUTES);
        return result;
    }
}

RestTemplate

典型场景 统一添加请求头/加密请求参数

java 复制代码
public class TraceInterceptor implements ClientHttpRequestInterceptor {
    @Override
    public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) {
        request.getHeaders().add("X-TraceId", UUID.randomUUID().toString());
        return execution.execute(request, body);
    }
}

// 注册水军
@Bean
public RestTemplate restTemplate() {
    RestTemplate rt = new RestTemplate();
    rt.getInterceptors().add(new TraceInterceptor());
    return rt;
}

Feign拦截器

典型场景 统一签名计算/Header透传

java 复制代码
public class FeignAuthInterceptor implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate template) {
        template.header("Authorization", "Bearer " + SecurityContext.getToken());
    }
}

@Configuration
public class FeignConfig {
    @Bean
    public FeignAuthInterceptor feignAuthInterceptor() {
        returnnew FeignAuthInterceptor();
    }
}

WebFilter

典型场景 响应式编程统一编码/跨域处理

java 复制代码
@Component
public class CorsWebFilter implements WebFilter {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain) {
        ServerHttpResponse response = exchange.getResponse();
        response.getHeaders().add("Access-Control-Allow-Origin", "*");
        return chain.filter(exchange);
    }
}

总结

顺序

Filter -> Interceptor -> AOP ,越早拦截越省力(但别在Filter里做业务)

性能

用Arthas监控拦截链路耗时

java 复制代码
# 查看HandlerInterceptor耗时
trace *.preHandle '#cost>10'
 
# 诊断AOP切面
watch com.example.aop.*Aspect * '{params,returnObj}' -x 3
相关推荐
半路程序员几秒前
Go内存泄漏排查pprof和trace使用
开发语言·后端·golang
WongLeer2 分钟前
Go + GORM 多级分类实现方案对比:内存建树、循环查询与 Preload
开发语言·后端·mysql·golang·gorm
一直都在5722 分钟前
MyBatis入门:CRUD、参数处理与防 SQL 注入
java·sql·mybatis
weixin_399380697 分钟前
TongWeb+TongDataGrid+TongHttpServer实现Session复制
java·tomcat
青云交8 分钟前
Java 大视界 -- Java+Flink CDC 构建实时数据同步系统:从 MySQL 到 Hive 全增量同步(443)
java·mysql·flink·实时数据同步·java+flink cdc·mysql→hive·全增量同步
开开心心就好8 分钟前
音频格式互转工具,支持Mp3ApeWavFlac互转
java·网络·c++·windows·qt·电脑·excel
Victor3569 分钟前
Hibernate(34)Hibernate的别名(Alias)是什么?
后端
Java猿_9 分钟前
开发 Java 项目,选哪个 IDE?Eclipse、MyEclipse 与 IntelliJ IDEA 深度对比
java·ide·eclipse
Icarus_9 分钟前
IDEA Android studio 快捷鍵
java·android studio·intellij-idea
小罗和阿泽10 分钟前
Java项目 简易图书管理系统
java·开发语言