目录
2、创建SpringConfig配置类,代替spring的配置文件
3、创建WebConfig配置类,代替SpringMVC的配置文件
1、注解配置SpringMVC
使用配置类和注解,代替web.xml和SpringMVC配置文件的功能。
1、创建初始化类,代替web.xml
对于SpringMVC,web.xml做的主要工作
配置SpringMVC的前端控制器,指定SpringMVC的核心配置文件路径
配置过滤器
web.xml如何被配置类替代
在JavaWeb阶段,就已经可以舍弃web.xml,转而使用配置类和注解,实现对servlet容器的配置。
在Servlet3.0环境中,容器会在类路径中查找实现javax.servlet.ServletContainerInitializer接口的类,如果找到的话就用它来配置Servlet容器。
Spring提供了这个接口的实现,名为SpringServletContainerInitializer,这个类反过来又会查找实现WebApplicationInitializer的类,并将配置的任务交给它们来完成。
Spring3.2引入了一个便利的WebApplicationInitializer基础实现,名为
AbstractAnnotationConfigDispatcherServletInitializer
,当我们的类扩展了AbstractAnnotationConfigDispatcherServletInitializer并将其部署到Servlet3.0容器的时候,容器会自动发现它,并用它来配置Servlet上下文。简单来说,
如果某个类继承了AbstractAnnotationConfigDispatcherServletInitializer类,它就会被servlet容器自动发现,并使用其中的配置来配置servlet容器
。这个过程,本质上是并不是由SpringMVC实现的。
实现步骤
- 在工程中,java目录下,创建config目录,里面创建WebInit类,作为替代web.xml的初始化类。
- 实现三个方法,分别指定Spring配置类、SpringMVC配置类、DispatherServlet映射规则。
- 如果要添加过滤器,可以重写getServletFilters()方法
//Web工程的初始化类,用于代替web.xml
//Web工程的初始化类,用于代替web.xml
public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
//指定Spring的配置类
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[]{SpringConfig.class};
}
//指定SpringMVC的配置类
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebConfig.class};
}
// 指定DispatcherServlet的映射规则,即url-pattern
@Override
protected String[] getServletMappings() {
return new String[]{"/"};
}
//添加过滤器
@Override
protected Filter[] getServletFilters() {
//设置字符编码的过滤器
CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
characterEncodingFilter.setEncoding("UTF-8");
characterEncodingFilter.setForceResponseEncoding(true);
//设置启用Http隐藏请求方法的过滤器
HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
return new Filter[]{characterEncodingFilter, hiddenHttpMethodFilter};
}
}
2、创建SpringConfig配置类,代替spring的配置文件
@Configuration
public class SpringConfig {
//ssm整合之后,spring的配置信息写在此类中
}
3、创建WebConfig配置类,代替SpringMVC的配置文件
SpringMVC的配置文件包含哪些内容
- 包扫描组件
- 视图解析器
- view-controller 视图控制器
- default-servlet-handler 默认Servlet
- 开启mvc注解驱动
- 文件上传解析器
- 异常处理
- 拦截器
//代替SpringMVC的配置文件
//将当前类标识为一个配置类
@Configuration
//扫描组件
@ComponentScan("com.csai.controller")
//开启mvc的注解驱动
@EnableWebMvc
public class WebConfig {
/*
配置Thymeleaf视图解析器
*/
//配置生成模板解析器
@Bean
public ITemplateResolver templateResolver() {
WebApplicationContext webApplicationContext = ContextLoader.getCurrentWebApplicationContext();
// ServletContextTemplateResolver需要一个ServletContext作为构造参数,可通过WebApplicationContext 的方法获得
ServletContextTemplateResolver templateResolver = new ServletContextTemplateResolver(webApplicationContext.getServletContext());
templateResolver.setPrefix("/WEB-INF/templates/");
templateResolver.setSuffix(".html");
templateResolver.setCharacterEncoding("UTF-8");
templateResolver.setTemplateMode(TemplateMode.HTML);
return templateResolver;
}
//生成模板引擎并为模板引擎注入模板解析器
@Bean
public SpringTemplateEngine templateEngine(ITemplateResolver templateResolver) {
SpringTemplateEngine templateEngine = new SpringTemplateEngine();
templateEngine.setTemplateResolver(templateResolver);
return templateEngine;
}
//生成视图解析器并未解析器注入模板引擎
@Bean
public ViewResolver viewResolver(SpringTemplateEngine templateEngine) {
ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
viewResolver.setCharacterEncoding("UTF-8");
viewResolver.setTemplateEngine(templateEngine);
return viewResolver;
}
}
注意
默认可能在package时,提示缺少web.xml文件。
此时需要在pom.xml的properties中,添加这条配置:
<failOnMissingWebXml>false</failOnMissingWebXml>
2、SpringMVC执行流程
1、SpringMVC的常用组件
-
DispatherServlet:前端控制器
- 由框架提供
- 作用:统一处理请求和响应,是整个流程控制的中心,由它调用其他组件来处理用户的请求
-
HandlerMapping:处理器映射器
- 由框架提供
- 作用:根据请求的URL、method等信息查找Handler(控制器方法),将请求和控制器方法进行映射
-
Handler:控制器(Controller)
- 由程序员开发
- 作用:在DispatherServlet的控制下,Handler对具体的用户请求进行处理
-
HandlerAdapter:控制器适配器
- 由框架提供
- 作用:匹配到控制器方法之后,通过HandlerAdapter调用控制器方法
-
ViewResolver:视图解析器
- 由框架提供
- 作用:进行视图解析,得到响应的视图
-
View:视图
- 由框架或视图技术提供
- 作用:将模型数据通过页面展示给用户
2、SpringMVC执行流程
- 用户向服务器发送请求,请求被SpringMVC 前端控制器 DispatherServlet捕获
- DispatherServlet对请求的URL地址进行解析,得到请求资源标识符URI,判断请求URI对应的映射
- 如果映射不存在:
- 判断是否配置了mvc:default-servlet-handler
- 如果没有配置,则控制台报错说找不到映射,浏览器显示404错误
- 如果有配置,则访问目标资源。此时一般访问的是静态资源。如果依然找不到,说明确实没有这个资源,浏览器显示404错误
- 如果映射存在,则根据该URI,调用HandlerMapping 获得该Handler 配置的所有相关对象(包括Handler对象以及Handler对象对应的拦截器),最后以HandlerExecutionChain执行链对象的形式返回。(
Handler指的就是控制器方法
) - DispatherServlet 根据获得的Handler,选择一个适合执行该Handler的HandlerAdapter
- 如果成功获得HandlerAdapter,此时将开始执行拦截器的preHandler()方法,多个拦截器时正向执行
- 提取Request域对象中的模型数据,填充Handler的形参,开始执行Handler(Controller)控制器方法,处理请求。在填充Hanlder的形参的过程中,根据配置,Spring将做一些额外的操作:
- HttpMessageConveter:将请求消息(如Json或xml等)转换成一个对象,将对象转换成指定的响应信息
- 数据转换:对请求消息进行数据转换,如String转换成Integer、Double等
- 数据格式化:对请求消息进行数据格式化,如将字符串转换成格式化数字,或格式化日期等
- 数据验证:验证数据的有效性(长度、格式等),验证结果将存储到BindingResult或Error中
- Handler执行完毕后,向DispatherServlet返回一个ModleAndView对象
- 执行拦截器的postHandler()方法,多个拦截器时逆向执行
- 根据返回的ModelAndView,判断是否存在异常:
- 如果存在异常,则执行HandlerExceptionResolver 异常处理器进行异常处理
- 如果不存在异常,则选择一个适合的ViewResolver进行视图解析,根据Model和View渲染视图
- 渲染视图完毕,执行拦截器的afterCompletion()方法,多个拦截器时逆向执行
- 将渲染结果返回客户端(浏览器)