Springboot 实现拦截器获取header内容

8 篇文章 0 订阅

背景

事情是这样的,最近项目做了个渗透测试,被查到了横向越权的问题,是因为前端传到后端的请求,经过APIportal的时候验证过了token,后端就没有去验证了,现在要加上这一步。

分析

既然是所有前端的请求都要做校验,那么如果一个接口一个接口的做当然是不可取的,而springmvc的拦截器可以在里面统一的进行处理,很适合我们的需求。

实现

那么我们就先来实现一下吧。

  • 首先实现一个拦截器:
@Component
public class AuthInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        log.info(">>>AuthInterceptor>>>>>>>在请求处理之前进行调用(Controller方法调用之前)");

        String token = request.getHeader("token");

        log.info("token : [ {} ]", token);

        //....处理逻辑

        return true;// 只有返回true才会继续向下执行,返回false取消当前请求
    }
}
  • 将拦截器配置进springboot中:
@Configuration
public class WebAuthConfig extends WebMvcConfigurationSupport {
    @Resource
    AuthInterceptor authInterceptor;

    @Override
    protected void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(authInterceptor).addPathPatterns("/**");

    }
}

这里需要注意,以前我们是用的WebMvcConfigurerAdapter,但是这个类已经过时了,对于一个强迫症来说,当然是得换掉它了,我们可以使用WebMvcConfigurer或者WebMvcConfigurationSupport,我这里使用的是WebMvcConfigurationSupport。

结果

接下来我们看看效果,随便打一个我们的接口:

可以看到控制台顺利的打出了日志!

相关导读:

springboot 拦截器不生效

Springboot实现过滤器

深入理解拦截器与过滤器

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
在Spring Boot中,可以通过自定义拦截器获取请求头。拦截器是Spring框架提供的一种机制,用于在请求处理之前或之后进行一些额外的处理。 要获取请求头,首先需要创建一个实现了HandlerInterceptor接口的拦截器类。在该类中,可以重写preHandle方法,在该方法中获取请求头信息。 下面是一个获取请求头的示例代码: ```java import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 获取请求头信息 String headerValue = request.getHeader("headerName"); System.out.println("Header Value: " + headerValue); // 返回true表示继续执行请求处理,返回false表示中断请求处理 return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 在请求处理之后进行一些处理 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 在请求完成之后进行一些处理 } } ``` 然后,在Spring Boot应用程序的配置类中注册该拦截器: ```java 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 { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new MyInterceptor()); } } ``` 这样,当有请求到达时,拦截器的preHandle方法会被调用,从而可以获取请求头信息。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值