常规配置(Controller加载控制)
- SpringMVC的处理器对应的bean必须按照规范格式开发,未避免加入无效的
bean
可通过bean加载过滤器进行包含设定或排除设定,表现层bean标注通常设定为@Controller
- 业务层与数据层bean加载由Spring控制,表现层bean加载由SpringMVC单独控制
- 表现层处理bean使用注解@Controller声明
- bean加载控制使用包含行性滤器
- 过滤器类型为通过注解进行过滤
- 过滤的注解名称为Controller
xml方式
<context:component-scan base-package="com.itzhuzhu">
<context:include-filter
type="annotation"
expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
静态资源加载
核心控制器拦截的是所有请求,需要对静态资源请求进行放行,通过配置放行资源实现
<!--放行指定类型静态资源配置方式,但是文件多了,这种方式很麻烦-->
<mvc:resources mapping="/img/**" location="/img/"/>
<mvc:resources mapping="/js/**" location="/js/"/>
<mvc:resources mapping="/css/**" location="/css/"/>
<!--SpringMVC提供的简化格式,可以放行所有普通资源调用-->
<mvc:default-servlet-handler/>
中文乱码处理
SpringMVC提供专用的中文字符过滤器,用于处理乱码问题
配置在 web.xml 里面
<!--乱码处理过滤器,与Servlet中使用的完全相同,差异之处在于处理器的类由Spring提供-->
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注解驱动
使用注解形式转化SpringMVC核心配置文件为配置类
@Configuration // 声明是一个配置类
@ComponentScan(value = "com.itzhuzhu",includeFilters =
@ComponentScan.Filter(type=FilterType.ANNOTATION,classes = {Controller.class}) // 代替Controller加载控制
)
// 要想代替静态资源加载需要实现WebMvcConfigurer,然后重写方法。下面两种方式代替的是静态资源加载的,选一个用就可以了
public class SpringMVCConfiguration implements WebMvcConfigurer{
// 注解配置放行指定资源格式
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/img/**").addResourceLocations("/img/");
registry.addResourceHandler("/js/**").addResourceLocations("/js/");
registry.addResourceHandler("/css/**").addResourceLocations("/css/");
}
//注解配置通用放行资源的格式
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();;
}
}
基于servlet3.0规范,自定义Servlet容器初始化配置类,加载SpringMVC核心配置类(代替web.xml文件的)
public class ServletContainersInitConfig extends AbstractDispatcherServletInitializer {
//创建Servlet容器时,使用注解的方式加载SPRINGMVC配置类中的信息,并加载成WEB专用的
//ApplicationContext对象
//该对象放入了ServletContext范围,后期在整个WEB容器中可以随时获取调用
@Override
protected WebApplicationContext createServletApplicationContext() {
AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
ctx.register(SpringMVCConfiguration.class);
return ctx;
}
//注解配置映射地址方式,服务于SpringMVC的核心控制器DispatcherServlet
@Override
protected String[] getServletMappings() {
return new String[]{"/"};
}
@Override
protected WebApplicationContext createRootApplicationContext() {
return null;
}
//乱码处理作为过滤器,在servlet容器启动时进行配置
@Override
public void onStartup(ServletContext servletContext) throws ServletException {
super.onStartup(servletContext);
CharacterEncodingFilter cef = new CharacterEncodingFilter();
cef.setEncoding("UTF-8");
FilterRegistration.Dynamic registration = servletContext.addFilter("characterEncodingFilter", cef);
// 添加映射地址
registration.addMappingForUrlPatterns(EnumSet.of(DispatcherType.REQUEST,DispatcherType.FORWARD,DispatcherType.INCLUDE),false,"/*");
}
}