Spring Boot 拦截器未拦截到请求

4
我已经为我的spring-boot应用程序编写了一个拦截器。但是当我访问端点时,它能够正常执行。拦截器无法拦截我的请求。
我做错了什么或者遗漏了什么?
以下是代码:
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {

    private static final String PATHS = "/services/api/**";

    @Autowired
    private AuthorizationInterceptor authInterceptor;

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(authInterceptor).addPathPatterns(PATHS);
    }



}

这里是 Interceptor 的代码:
@Component
public class AuthorizationInterceptor implements HandlerInterceptor {
    private static final Logger LOGGER = LoggerFactory.getLogger(AuthorizationInterceptor.class);
    private static final String MSG_BAD_INPUT = "Very Bad Input";
    private static final int MAX_URI_LENGTH = 4;

    @Override
    public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
            throws Exception {
        // TODO Auto-generated method stub

    }

    @Override
    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
            throws Exception {
        // TODO Auto-generated method stub

    }

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        System.out.println("Inside Prehandle:::::::------->");
        this.checkURILength(request);
        System.out.println("After checking:::::::::::---->");
        return true;

    }

    private void checkURILength(HttpServletRequest request) {
        if (request.getRequestURI().length() > MAX_URI_LENGTH) {
            LOGGER.error("Request URI is too long");
            throw new InvalidInputException(MSG_BAD_INPUT);
        }
    }


}

现在当我访问我的Spring Boot应用的端点时,一切都正常。

http://localhost:8181/services/api/companies

基本上它根本没有调用prehandle方法。我错过了什么吗?

但是,当我将“PATHS =” /services/api/**“”更改为“PATHS =” /**“”时,它能够拦截请求,但我不明白为什么它在上述情况下失败了。 - sromit
你应该列出你的依赖关系。否则可能会出现其他问题。 - Jess Chen
2个回答

1
你使用了 @EnableWebMvc 吗?
@EnableWebMvc
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
  ...
}

很有趣,它没有使用addPathPatterns()就能工作吗? - Hexiler
我知道我只是好奇,也许会引起一些问题,但那不应该成为问题。 顺便问一下,你是否在xml中创建了拦截器的bean?请尝试以下代码替代@Autowired @Bean AuthorizationInterceptor authorizationInterceptor () { return new AuthorizationInterceptor (); } registry.addInterceptor(authorizationInterceptor()).addPathPatterns(PATHS);编辑:抱歉代码格式化有误... :D - Hexiler
如果我将 PATHS = "/services/api/**" 更改为 PATHS = "/**",它可以拦截请求,但我不明白为什么上面的代码会失败。 - sromit
你有一个控制器可以处理这个请求吗? 例如:@RequestMapping(value = "/services/api/something") - Hexiler

0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接