spring boot 拦截器不生效的原因

1. 没加@Component或者@Configuration注解

2. @ComponentScan没扫描到

     如果启动类和拦截类在平级或者拦截类父级平级的情况下,ComponentScan一般都会扫描到,除非启动类中指定了

3. 路径配置错了

     拦截器的路径配置错误,类不在范围;

4. 已经有类集成了拦截类

    项目中有类已经集成了 WebMvcConfigurationSupport 或 WebMvcConfigurerAdapter 或  WebMvcConfigurer 你再定集成这些类也不会生效;

   其中资源访问配置类,swagger等配置都会使用WebMvcConfigurer来配置,需要把这些类整合在一个类中就可以了;

 

登录验证DEMO:

拦截配置类:

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * Created By: hdx
 * Date: 2021-04-07 16:53
 */
@Configuration
public class ResourceConfig implements WebMvcConfigurer {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        //可以访问localhost:8095/static/images/image.jpg
        registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/");
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new AccessInterceptor())
                .addPathPatterns("/**")
                .excludePathPatterns("/sys/login");

    }
}

自定义拦截器:

import cn.dev33.satoken.stp.StpUtil;
import com.ajr.alllink.util.ResponseMessage;
import com.ajr.alllink.util.ResponseMsgEnum;
import com.ajr.alllink.util.Result;
import com.alibaba.fastjson.JSONObject;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

/**
 * Created By: hdx
 * Date: 2021-04-19 14:24
 */
public class AccessInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        Boolean boo = StpUtil.isLogin();
        System.out.println("全局拦截器 是否登录: "+boo);
        // 未登录
        if(!boo){
            ResponseMessage error = Result.error(ResponseMsgEnum.TOKEN_ERROR.getCode());
            String json = JSONObject.toJSONString(error);
            response.setCharacterEncoding("UTF-8");
            response.setContentType("application/json; charset=utf-8");
            PrintWriter out = null;
            try {
                out = response.getWriter();
                out.append(json);
                System.out.println("全局拦截器 返回数据: "+json);
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                if (out != null) {
                    out.close();
                }
            }
            return false;
        }
        return true;
    }
}

除了/sys/login接口不需要登录外,其他接口都需要登录;

登录使用的sa-token框架, sa-token 地址:

 

  • 10
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Spring Boot提供了拦截器(Interceptor)的机制,可以在请求进入控制器之前或之后进行一些自定义的处理。拦截器可以用于权限验证、日志记录、异常处理等。 要创建一个拦截器,首先需要实现`HandlerInterceptor`接口,并实现其中的三个方法:`preHandle`、`postHandle`和`afterCompletion`。`preHandle`方法在请求进入控制器之前被调用,`postHandle`方法在请求处理完毕后但尚未返回前被调用,`afterCompletion`方法在请求返回后被调用。 下面是一个简单的示例: ```java public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在这里进行权限验证等操作 return true; // 返回true表示继续执行后续的拦截器和控制器,返回false表示中断请求 } @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 @Configuration public class AppConfig extends WebMvcConfigurerAdapter { @Autowired private MyInterceptor myInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(myInterceptor); } } ``` 这样,拦截器就会生效了。你可以根据具体需求在拦截器的各个方法中进行相应的处理逻辑。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值