这篇文章主要讲解了“springMVC的工作原理和机制以及配置”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springMVC的工作原理和机制以及配置”吧!
工作原理
下面的是springMVC的工作原理图:
客户端发出一个http请求给web服务器,web服务器对http请求进行解析,如果匹配DispatcherServlet的请求映射路径(在web.xml中指定),web容器将请求转交给DispatcherServlet.
DipatcherServlet接收到这个请求之后将根据请求的信息(包括URL、Http方法、请求报文头和请求参数Cookie等)以及HandlerMapping的配置找到处理请求的处理器(Handler)。
3-4、DispatcherServlet根据HandlerMapping找到对应的Handler,将处理权交给Handler(Handler将具体的处理进行封装),再由具体的HandlerAdapter对Handler进行具体的调用。
Handler对数据处理完成以后将返回一个ModelAndView()对象给DispatcherServlet。
Handler返回的ModelAndView()只是一个逻辑视图并不是一个正式的视图,DispatcherSevlet通过ViewResolver将逻辑视图转化为真正的视图View。
Dispatcher通过model解析出ModelAndView()中的参数进行解析最终展现出完整的view并返回给客户端。
工作机制是什么
Control的调用(续)
接着对于(二)的补充:主要是小结下Control的处理逻辑的关键操作;
对于control的处理关键就是:DispatcherServlet的handlerMappings集合中根据请求的URL匹配每一个handlerMapping对象中的某个handler,匹配成功之后将会返回这个handler的处理连接handlerExecutionChain对象。而这个handlerExecutionChain对象中将会包含用户自定义的多个handlerInterceptor对象。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | protected HandlerExecutionChain getHandler(HttpServletRequest request) throws Exception { for (HandlerMapping hm : this.handlerMappings) { if (logger.isTraceEnabled()) { logger.trace( "Testing handler map [" + hm + "] in DispatcherServlet with name '" + getServletName() + "'"); } HandlerExecutionChain handler = hm.getHandler(request); if (handler != null) { return handler; } } return null; } |
而对于handlerInterceptor接口中定义的三个方法中,preHandler和postHandler分别在handler的执行前和执行后执行,afterCompletion在view渲染完成、在DispatcherServlet返回之前执行。
愿意了解更多的技术知识分享可参考源码:http://minglisoft.cn/technology
朋友需要请加球球:2042849237
springmvc.xml的配置
视图解析器的配置:
<!-- 配置视图解析器 --> <"org.springframework.web.servlet.view.InternalResourceViewResolver"> <!-- 使用前缀和后缀 --> <"prefix" "/"></<"suffix" ".jsp"></</<!-- 使用组件扫描的方式可以一次扫描多个Controller --> <"com.wxisme.ssm.controller">
也可以使用单个的配置方式,需要指定Controller的全限定名。
<bean name="/queryUser.action" class="com.wxisme.ssm.controller.Controller1"/>
配置注解的处理器适配器和处理器映射器:
<!-- 注解的处理器适配器 --> <"org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> <!-- 注解的处理器映射器 --> <"org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
也可以使用下面的简化配置:
<!-- 配置注解的处理器映射器和处理器适配器 --> <"conversionService"></<<!-- 直接定义拦截所有请求 --> <"com.wxisme.ssm.interceptor.IdentityInterceptor"></<!-- <mvc:interceptor> 拦截所有路径的请求 包括子路径 <mvc:mapping path="/**"/> <bean class="com.wxisme.ssm.interceptor.IdentityInterceptor"></bean> </mvc:interceptor> --> </<!-- 定义全局异常处理器 --> <!-- 只有一个全局异常处理器起作用 --> <"exceptionResolver" "com.wxisme.ssm.exception.OverallExceptionResolver"></<!--配置上传文件数据解析器 --> <"multipartResolver" "org.springframework.web.multipart.commons.CommonsMultipartResolver"> <"maxUploadSize"> <</</</<!-- 自定义参数类型绑定 --> <"conversionService" "org.springframework.format.support.FormattingConversionServiceFactoryBean"> <"converters"> <<!-- 日期类型绑定 --> <"com.wxisme.ssm.controller.converter.DateConverter"/> </</</<"/images/**" "/images/" /> <"/css/**" "/css/" /> <"/js/**" "/js/" /> <"/imgdata/**" "/imgdata/" />
也可以使用默认,但是需要在web.xml中配置。
<!-- 访问静态资源文件 --> <!-- <mvc:default-servlet-handler/> 需要在web.xml中配置-->
完全可以不拦截所有路径,大可避免这个问题的发生。
完整的配置大概是这样的,需要注意xml文件的命名空间,有时候会有影响的。
"1.0" encoding="UTF-8"<"http://www.springframework.org/schema/beans" "http://www.w3.org/2001/XMLSchema-instance" "http://www.springframework.org/schema/context" "http://www.springframework.org/schema/mvc" "http://www.springframework.org/schema/jdbc" "http://www.springframework.org/schema/jee" "http://www.springframework.org/schema/aop" "http://www.springframework.org/schema/tx" "http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop.xsd"> <!-- 配置视图解析器 --> <"org.springframework.web.servlet.view.InternalResourceViewResolver"> <!-- 使用前缀和后缀 --> <"prefix" "/"></<"suffix" ".jsp"></</<!-- 使用组件扫描的方式可以一次扫描多个Controller --> <"com.wxisme.ssm.controller"> </<!-- 配置注解的处理器映射器和处理器适配器 --> <"conversionService"></<!-- 自定义参数类型绑定 --> <"conversionService" "org.springframework.format.support.FormattingConversionServiceFactoryBean"> <"converters"> <<!-- 日期类型绑定 --> <"com.wxisme.ssm.controller.converter.DateConverter"/> </</</<!-- 访问静态资源文件 --> <!-- <mvc:default-servlet-handler/> 需要在web.xml中配置--> <"/images/**" "/images/" /> <"/css/**" "/css/" /> <"/js/**" "/js/" /> <"/imgdata/**" "/imgdata/" /> <!-- 定义拦截器 --> <<!-- 直接定义拦截所有请求 --> <"com.wxisme.ssm.interceptor.IdentityInterceptor"></<!-- <mvc:interceptor> 拦截所有路径的请求 包括子路径 <mvc:mapping path="/**"/> <bean class="com.wxisme.ssm.interceptor.IdentityInterceptor"></bean> </mvc:interceptor> --> </<!--配置上传文件数据解析器 --> <"multipartResolver" "org.springframework.web.multipart.commons.CommonsMultipartResolver"> <"maxUploadSize"> <</</</<!-- 定义全局异常处理器 --> <!-- 只有一个全局异常处理器起作用 --> <"exceptionResolver" "com.wxisme.ssm.exception.OverallExceptionResolver"></</beans>
感谢各位的阅读,以上就是“springMVC的工作原理和机制以及配置”的内容了,经过本文的学习后,相信大家对springMVC的工作原理和机制以及配置这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!