@Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(getAuthorizationInterceptor()) .addPathPatterns("/**") .excludePathPatterns("/static/**");//放行路径 super.addInterceptors(registry); }这段代码是什么意思
时间: 2023-08-27 09:13:03 浏览: 46
这段代码是在Web应用程序中注册一个拦截器,并将`AuthorizationInterceptor`对象添加到拦截器链中。`addPathPatterns("/**")`表示拦截所有的请求路径,`excludePathPatterns("/static/**")`表示放行以`/static/`开头的请求路径,即不对这些路径进行拦截。
当一个请求到达时,拦截器会先执行`getAuthorizationInterceptor()`方法返回的`AuthorizationInterceptor`对象的`preHandle()`方法,进行权限校验。如果权限校验通过,则继续执行后续逻辑;否则,拦截器会返回错误信息,不再继续执行后续逻辑。
`super.addInterceptors(registry)`表示将拦截器链注册到Spring MVC配置中,以便生效。
相关问题
解释public class InterceptorConfig extends WebMvcConfigurationSupport{ @Bean public AuthorizationInterceptor getAuthorizationInterceptor() { return new AuthorizationInterceptor(); } @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(getAuthorizationInterceptor()).addPathPatterns("/**").excludePathPatterns("/static/**"); super.addInterceptors(registry); } /** * springboot 2.0配置WebMvcConfigurationSupport之后,会导致默认配置被覆盖,要访问静态资源需要重写addResourceHandlers方法 */ @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/**") .addResourceLocations("classpath:/resources/") .addResourceLocations("classpath:/static/") .addResourceLocations("classpath:/admin/") .addResourceLocations("classpath:/front/") .addResourceLocations("classpath:/public/"); super.addResourceHandlers(registry); } }
这段代码是一个拦截器配置类,它继承了WebMvcConfigurationSupport类,并且重写了addInterceptors和addResourceHandlers方法。
其中,getAuthorizationInterceptor()方法返回一个AuthorizationInterceptor对象,它是一个自定义的拦截器。
addInterceptors方法用于配置拦截器,这里将getAuthorizationInterceptor()加入到了拦截器链中,并指定了拦截的路径为"/**",但是排除了静态资源的路径"/static/**"。
addResourceHandlers方法则是用于配置静态资源的位置,这里将"/resources/"、"/static/"、"/admin/"、"/front/"和"/public/"这些路径都映射到"/**"路径下,这样就可以通过访问这些路径下的静态资源了。
package com.config; import org.springframework.context.annotation.Bean; 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.WebMvcConfigurationSupport; import com.interceptor.AuthorizationInterceptor; @Configuration public class InterceptorConfig extends WebMvcConfigurationSupport{ @Bean public AuthorizationInterceptor getAuthorizationInterceptor() { return new AuthorizationInterceptor(); } @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(getAuthorizationInterceptor()).addPathPatterns("/**").excludePathPatterns("/static/**"); super.addInterceptors(registry); } /** * springboot 2.0配置WebMvcConfigurationSupport之后,会导致默认配置被覆盖,要访问静态资源需要重写addResourceHandlers方法 */ @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/**") .addResourceLocations("classpath:/resources/") .addResourceLocations("classpath:/static/") .addResourceLocations("classpath:/admin/") .addResourceLocations("classpath:/front/") .addResourceLocations("classpath:/public/"); super.addResourceHandlers(registry); } }
这是一个 Java Spring 的配置类,用于配置拦截器和静态资源访问路径。其中,@Configuration 注解表示这是一个配置类,@Bean 注解表示该方法返回一个 Bean 对象,getAuthorizationInterceptor() 方法返回一个 AuthorizationInterceptor 对象,用于验证用户登录状态。addInterceptors() 方法用于添加拦截器,这里将 AuthorizationInterceptor 对象添加到所有路径上,但排除了 /static/ 路径。addResourceHandlers() 方法用于配置静态资源访问路径,这里将 classpath:/resources/、classpath:/static/、classpath:/admin/、classpath:/front/、classpath:/public/ 这几个路径下的静态资源都配置为可访问的。