SpringMVC的核心组件
DispatcherServlet—–>控制器,请求入口
HanderMapping———>控制器,请求派发
Controller————>控制器,请求处理流程
ModelAndView———->模型,封装业务处理结果和视图
ViewResolver———->视图,视图显示处理器
处理流程
浏览器向Spting发出请求,请求交给前端控制器DispatcherServlet处理。
控制器通过HanderMapping找到相应的Controller组件处理请求。
执行Controller组件约定的方法处理请求,在约定方法调用模型组件完成业务处理,约定方法可以返回一个ModelAndView对象,这个对象封装了业务处理结果数据和视图名称信息。
控制器接收ModelAndView之后,调用ViewResolver组件,定位View(JSP)并传递信息,生成响应界面结果。
注释配置相对于XML配置具有很多的优势:
它可以充分利用Java的反射机制获取类结构信息,这些信息可以有效减少配置的工作。如使用JPA注释配置ORM映射时,我们就不需要指定PO的属性名、类型等信息,如果关系表字段和PO属性名、类型都一致,您甚至无需编写任务属性映射信息——因为这些信息都可以通过Java反射机制获取。
注释和Java代码位于一个文件中,而XML配置采用独立的配置文件,大多数配置信息在程序开发完成后都不会调整,如果配置信息和Java代码放在一起,有助于增强程序的内聚性。而采用独立的XML配置文件,程序员在编写一个功能时,往往需要在程序文件和配置文件中不停切换,这种思维上的不连贯会降低开发效率。
Controller组件
Controller组件负责执行具体的业务处理,编写时需要实现Controller接口及约定的方法。
ModelAndView组件
Controller约定组件中后会返回一个ModelAndView对象,这个对象封装了业务处理结果模型数据和视图信息。
ModelAndView构造器如下:
-ModelAndView(StringviewName)
-ModelAndView(StringviewName,Mapmodel)
其中viewName是jsp页面的名字,model的数据存储到request的attribute中
HanderMapping组件
通过HanderMapping组件,DispatcherServlet控制器可以将http请求映射到Controller组件上。
-SimpleUserHandlerMapping维持一个http请求和Controller映射关系(map)根据列表对应关系调用Controller.
SimpleUserHandlerMapping使用
1
2
3
4
5
6
7
8
9
10
|
< bean class = "" > < property name = "mappings" > < props > < prop key = "/login.form" >loginController</ prop > < props > </ prop key = "/hello.form" >helloController</ prop > </ property > </ bean > < bean id = "helloController" class = "org.test.HelloController" /> |
上面SimpleUserHandlerMapping标签中的helloController正对应着下面bean标签中id为helloController的组件。
RequestMappingHandlerMapping
ResquestMappingHandlerAdapter
在Controller类和方法上使用@ResquestMapping注解指定对应的客户http请求。
ViewResolver组件
所有Controller组件都返回一个ModelAndView实例,封装了视图名,Spring中的视图以名字为标识,视图解析器ViewResolver通过名字来解析视图。
InternalResourceViewResolver对Servlet和JSP的包装,使用示例:
1
2
3
4
|
< bean id = "jspViewResolver" class = "" > < property name = "prefix" value = "/WEB-INF/jsp/" /> < property name = "suffix" value = ".jsp" /> </ bean > |
比如:视图名hello通过上述配置可以映射到/WEB-INF/hello.jsp
Controller注解
我们一般使用@Controller注解声明Controller组件,这样便更加灵活,可以不用像前面那样实现Controller接口。
1
2
3
4
5
6
|
@Controller public class HelloController{ public String execute(){ return "Hello" ; } } |
使用上面注解有个前提条件就是要开启注解扫描:
1
|
< context:component-scan base-package = "org.test.controller" > |
base-package里面写的是Controller组件所在包。
ResquestMapping注解
ResquestMapping表明这个类或者方法与哪一个请求对应。
1
2
3
4
5
6
7
8
|
@Controller @ResquestMapping ( "/test1" ) public class HelloController{ @ResquestMapping ( "/hello.form" ) public String helloExecute(){ return "Hello" ; } } |
如果需要使用RequestMapping则需要在spring的XML配置文件里定义RequestMappingHandlerMapping(类定义前)和RequestMappingAdapter(方法定义前)两个bean组件,比如(sping3.1版本需要定义):
1
2
|
< bean class = ".......RequestMappingMapping" /> < bean class = ".......RequestMappingAdapter" /> |
spring3.2版本不需要定义了
1
|
< mvc:annotation-driven /> |
总结
以上就是本文关于Spring的注解简单介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/sinat_15274667/article/details/51585532