springMVC的生命周期,听到的时候都没有反应过来,springMVC还有生命周期?现在看来生命周期就是springMVC的流程,SpringMVC是MVC思想的一种实现,下面看一下MVC思想的流程图:
MVC的核心思想如上图,那么springMVC是如何实现MVC的思想的呢?
第一步:发起请求到前端控制器(DispatcherServlet)
第二步:前端控制器请求HandlerMapping(处理器映射器)查找 Handler
可以根据xml配置、注解进行查找
第三步:处理器映射器HandlerMapping向前端控制器返回Handler
第四步:前端控制器调用处理器适配器去执行Handler
第五步:处理器适配器去执行Handler
第六步:Handler执行完成给适配器返回ModelAndView
第七步:处理器适配器向前端控制器返回ModelAndView
ModelAndView是springmvc框架的一个底层对象,包括 Model和view
第八步:前端控制器请求视图解析器去进行视图解析
根据逻辑视图名解析成真正的视图(jsp)
第九步:视图解析器向前端控制器返回View
第十步:前端控制器进行视图渲染
视图渲染将模型数据(在ModelAndView对象中)填充到request域
第十一步:前端控制器向用户响应结果
代码示例
(1)在WEB-INF/web.xml中加入如下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
< servlet >
< servlet-name >dispatcherServlet</ servlet-name >
< servlet-class >org.springframework.web.servlet.DispatcherServlet</ servlet-class >
< init-param >
< param-name >contextConfigLocation</ param-name >
< param-value >
classpath*:spring-servlet.xml
</ param-value >
</ init-param >
< load-on-startup >1</ load-on-startup >
</ servlet >
< servlet-mapping >
< servlet-name >dispatcherServlet</ servlet-name >
< url-pattern >*.html</ url-pattern >
</ servlet-mapping >
|
上述的配置的就是前端控制器DispatcherServlet,在servlet-mapping配置了*.html,意味着所有以.html结尾的请求多会通过这个servlet。当dispatcherServlet启动时,会默认在web-info目录下查找一个spring-servlet.xml的配置文件,上面我们通过显示指定了这个文件的位置,即在类路径底下的spring-servlet.xml。如果我们没有指定配置文件的名称Spring会在web应用的WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml的配置文件如dispatcher-servlet.xml
(2)在类路径底下添加spring-servlet.xml文件
1
2
3
4
5
6
7
8
9
|
<? xml version = "1.0" encoding = "UTF-8" ?>
< beans xmlns = "http://www.springframework.org/schema/beans" >
< context:component-scan base-package = "com.pango.spring.helloworld.controller" />
< bean id = "viewResolver" class = "org.springframework.web.servlet.view.UrlBasedViewResolver" >
< property name = "viewClass" value = "org.springframework.web.servlet.view.JstlView" />
< property name = "prefix" value = "/WEB-INF/jsp/" />
< property name = "suffix" value = ".jsp" />
</ bean >
</ beans >
|
上面这个文件,我们定义了一个 context标签,这样的标签定义了以后,当spring在启动时,会加载com.pango.spring.helloworld.controller这个包下及子包下的所有的组件(这是包的自动扫描机制,即spring会将标有@Controller @Component等类加载到spring容器管理中)。
后面配置了bean标签,ViewResolver是一个试图解析器,就是springMVC生命周期中的第五步,当我们从后端控制器中返回的视图时,前端控制器就根据这一段配置来返回一个具体的视图,如后端控制返回的是一个hello,根据上面的配置,最后前端控制器会组并成这样的一个址:/web-inf/jsp/hello.jsp,然后从/web-inf/jsp/这个目录下面查找一个hello.jsp返回客户端。
(3)在包底下写一个HelloWorldController的类
1
2
3
4
5
6
7
8
|
@Controller
public class HelloWorldController{
@RequestMapping (value= "/hello" )
public String sayHello(ModelMap modelMap){
modelMap.put( "sayHello" , "hello world" );
return "/hello" ;
}
}
|
Controller即声明这个类是一个控制器,上面第二部分我们说明了,只要加了@Controller标示的,spring会通过自动扫描机制,将这个类纳入spring容器管理中。 @RequestMapping(value="/hello"),这个定义的就是一个请求路径,只要符合/hello路径的都会交给这个控制器的sayhello方法来处理。最后我们返回/hello的视图给客户端。
小结
初步的了解了一下Java中springMVC的生命周期,它是MVC思想的一种实现,之前听过MVC是一种设计模式,但是在经典的23个设计模式中并没有MVC模式,它其实是观察者模式(Observer)(Pub/Sub), 策略模式(Strategy)和组合模式(Composite)的一个整合,详细的可以进一步研究。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。