Spring的注解简单介绍
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使用
<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的包装,使用示例:
<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接口。
@Controller public class HelloController{ public String execute(){ return "Hello"; } }
使用上面注解有个前提条件就是要开启注解扫描:
<context:component-scan base-package="org.test.controller">
base-package里面写的是Controller组件所在包。
ResquestMapping注解
ResquestMapping表明这个类或者方法与哪一个请求对应。
@Controller @ResquestMapping("/test1") public class HelloController{ @ResquestMapping("/hello.form") public String helloExecute(){ return "Hello"; } }
如果需要使用RequestMapping则需要在spring的XML配置文件里定义RequestMappingHandlerMapping(类定义前)和RequestMappingAdapter(方法定义前)两个bean组件,比如(sping3.1版本需要定义):
<bean class=".......RequestMappingMapping"/> <bean class=".......RequestMappingAdapter"/>
spring3.2版本不需要定义了
<mvc:annotation-driven/>
总结
以上就是本文关于Spring的注解简单介绍的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
相关文章
IntelliJ IDEA 2022.1.1创建java项目的详细方法步骤
最近安装了IntelliJ IDEA 2022.1.1,发现新版本的窗口还有些变化的,所以下面这篇文章主要给大家介绍了关于IntelliJ IDEA 2022.1.1创建java项目的详细方法步骤,文中通过图文介绍的非常详细,需要的朋友可以参考下2022-07-07springboot使用Thymeleaf报错常见的几种解决方案
这篇文章主要介绍了springboot使用Thymeleaf报错常见的几种解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-11-11修改SpringBoot 中MyBatis的mapper.xml文件位置的过程详解
由于MyBatis默认的mapper.xml的扫描位置是resource文件下,但是不可能整个项目的mapper.xml文件都放在resource下,如果文件较少还行,但是如果文件比较多,太麻烦了,所以本文给大家介绍了修改SpringBoot 中MyBatis的mapper.xml文件位置的过程,需要的朋友可以参考下2024-08-08
最新评论