一、SpringMVC完全注解开发
使用配置类和注解代替web.xml和SpringMVC配置文件的功能。
(一)创建初始化类,代替web.xml
- 在我们之前的web.xml中,我们配置了:CharacterEncodingFilter过滤器、HiddenHttpMethodFilter过滤器和DispatcherServlet前端控制器
- 在Servlet3.0环境中,容器会在类路径中查找实现javax.servlet.ServletContainerInitializer接口的类,如果找到的话就用它来配置Servlet容器(Tomcat服务器)。Spring提供了这个接口的实现,名为SpringServletContainerInitializer,这个类反过来又会查找实现WebApplicationInitializer的类并将配置的任务交给它们来完成。Spring3.2引入了一个便利的WebApplicationInitializer基础实现,名为AbstractAnnotationConfigDispatcherServletInitializer,当我们的类扩展了AbstractAnnotationConfigDispatcherServletInitializer并将其部署到Servlet3.0容器的时候,容器会自动发现它,并用它来配置Servlet上下文(代替了web.xml的工作)。
- AbstractAnnotationConfigDispatcherServletInitializer类中有三个必须重写的抽象方法:
protected String[] getServletMappings()
:指定DispatcherServlet的映射规则,即<url-pattern></url-pattern>
protected Class<?>[] getRootConfigClasses()
:指定Spring的配置类protected Class<?>[] getServletConfigClasses()
:指定SpringMVC的配置类
import org.springframework.web.filter.CharacterEncodingFilter;
import org.springframework.web.filter.HiddenHttpMethodFilter;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
import javax.servlet.Filter;
//web工程的初始化类,用来代替web.xml
public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
//指定spring的配置类
@Override
protected Class<?>[] getRootConfigClasses() {
//SpringConfig类需要自己定义,看下文
return new Class[]{
SpringConfig.class};
}
//指定springMVC的配置类
@Override
protected Class<?>[] getServletConfigClasses() {
//WebConfig类需要自己定义,看下文
return new Class[]{
WebConfig.class};
}
//指定DispatcherServlet的映射规则,即url-pattern
@Override
protected String[] getServletMappings() {
return new String[]{
"/"};
}
//注册过滤器
@Override
protected Filter[] getServletFilters() {
//注册CharacterEncodingFilter过滤器
CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
//给属性赋值
characterEncodingFilter.setEncoding("UTF-8");
characterEncodingFilter.setForceResponseEncoding(true);
//注册HiddenHttpMethodFilter过滤器
HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
return new Filter[]{
characterEncodingFilter, hiddenHttpMethodFilter};
}
}
(二)创建SpringConfig配置类,代替spring的配置文件
//@Configuration将当前类标识为一个配置类
@Configuration
public class SpringConfig {
//ssm整合之后,spring的配置信息写在此类中
}
(三)创建WebConfig配置类,代替SpringMVC的配置文件
我们之前SpringMVC的配置文件中,做了以下工作:
- 扫描组件
- 配置ThymeleafViewResolver视图解析器
- 配置视图控制器
<mvc:view-controller></mvc:view-controller>
- 开放对静态资源的访问
<mvc:default-servlet-handler />
(mvc:default-servlet-handler的作用?) - 开启mvc注解驱动
<mvc:annotation-driven />
- 配置文件上传解析器CommonsMultipartResolver
- 配置异常处理器
- 配置拦截器
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 自动扫描包 -->
<context:component-scan base-package="com.fox.mvc"/>
<!-- 配置Thymeleaf视图解析器 -->
<bean id="viewResolver" class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
<property name="order" value="1"/>
<property name="characterEncoding" value="UTF-8"/>
<property name="templateEngine">
<bean class="org.thymeleaf.spring5.SpringTemplateEngine">
<property name="templateResolver">
<bean class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver">
<!-- 视图前缀 -->
<property name="prefix" value="/WEB-INF/templates/"/>
<!-- 视图后缀 -->
<property name="suffix" value=".html"/>
<property name="templateMode" value="HTML5"/>
<property name="characterEncoding" value="UTF-8" />
</bean>
</property>
</bean>
</property>
</bean>
<!--配置视图控制器view-controller-->
<mvc:view-controller path="/" view-name="index"></mvc:view-controller>
<!--配置文件上传解析器-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"></bean>
<!--开放对静态资源的访问-->
<mvc:default-servlet-handler />
<!--开启mvc的注解驱动-->
<mvc:annotation-driven/>
<!--配置拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--可以通过ref或bean标签设置拦截器,通过mvc:mapping设置需要拦截的请求,
通过mvc:exclude-mapping设置需要排除的请求,即不需要拦截的请求-->
<mvc:mapping path="/**"/>