项目一启动就会执行这个配置类,这个配置类实现了WebMvcConfigurer接口
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
//自己定义的权限拦截器
@Resource
private PermissionInterceptor permissionInterceptor;
//自己定义的cookie拦截器
@Resource
private CookieInterceptor cookieInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
//对全部的接口进行权限拦截
registry.addInterceptor(permissionInterceptor).addPathPatterns("/**");
//对全部的接口进行cookie拦截
registry.addInterceptor(cookieInterceptor).addPathPatterns("/**");
}
}
WebMvcConfigurer接口提供了多个方法,可以用于配置以下方面:
1.拦截器(Interceptors):通过addInterceptors方法可以注册自定义的拦截器,用于在请求处理过程中进行拦截和处理。可以用于实现权限验证、日志记录等功能。
2.跨域资源共享(CORS):通过addCorsMappings方法可以配置跨域资源共享,允许跨域请求的来源、方法和头部信息。
3.视图解析器(View Resolvers):通过configureViewResolvers方法可以配置视图解析器,用于将控制器返回的逻辑视图名称解析为实际的视图对象。
4.静态资源处理(Static Resources):通过addResourceHandlers方法可以配置静态资源的处理,例如图片、CSS、JavaScript等文件的访问路径和存放位置。
5.内容协商(Content Negotiation):通过configureContentNegotiation方法可以配置内容协商策略,根据请求的媒体类型选择合适的响应内容。
6.消息转换器(Message Converters):通过extendMessageConverters方法可以配置消息转换器,用于处理请求和响应的消息体转换。
7.参数解析器(Argument Resolvers):通过addArgumentResolvers方法可以注册自定义的参数解析器,用于解析请求中的参数并传递给控制器方法。
8.返回值处理器(Return Value Handlers):通过addReturnValueHandlers方法可以注册自定义的返回值处理器,用于处理控制器方法的返回值并生成响应。
配置拦截器:
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
//自己定义的权限拦截器
@Resource
private PermissionInterceptor permissionInterceptor;
//自己定义的cookie拦截器
@Resource
private CookieInterceptor cookieInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
//对全部的接口进行权限拦截
registry.addInterceptor(permissionInterceptor).addPathPatterns("/**");
//对全部的接口进行cookie拦截
registry.addInterceptor(cookieInterceptor).addPathPatterns("/**");
}
}
配置跨域资源共享和视图解析器:
@Configuration
public class ResourcesConfig implements WebMvcConfigurer
{
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry)
{
/** 本地文件上传路径 */
registry.addResourceHandler(Constants.RESOURCE_PREFIX + "/**")
.addResourceLocations("file:" + RuoYiConfig.getProfile() + "/");
/** swagger配置 */
registry.addResourceHandler("/swagger-ui/**")
.addResourceLocations("classpath:/META-INF/resources/webjars/springfox-swagger-ui/");
}
/**
* 跨域配置
*/
@Bean
public CorsFilter corsFilter()
{
CorsConfiguration config = new CorsConfiguration();
config.setAllowCredentials(true);
// 设置访问源地址
config.addAllowedOriginPattern("*");
// 设置访问源请求头
config.addAllowedHeader("*");
// 设置访问源请求方法
config.addAllowedMethod("*");
// 有效期 1800秒
config.setMaxAge(1800L);
// 添加映射路径,拦截一切请求
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
source.registerCorsConfiguration("/**", config);
// 返回新的CorsFilter
return new CorsFilter(source);
}
}