您好,登錄后才能下訂單哦!
這篇文章主要講解了“springMVC的工作原理和機制以及配置”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“springMVC的工作原理和機制以及配置”吧!
下面的是springMVC的工作原理圖:
1、客戶端發出一個http請求給web服務器,web服務器對http請求進行解析,如果匹配DispatcherServlet的請求映射路徑(在web.xml中指定),web容器將請求轉交給DispatcherServlet.
2、DipatcherServlet接收到這個請求之后將根據請求的信息(包括URL、Http方法、請求報文頭和請求參數Cookie等)以及HandlerMapping的配置找到處理請求的處理器(Handler)。
3-4、DispatcherServlet根據HandlerMapping找到對應的Handler,將處理權交給Handler(Handler將具體的處理進行封裝),再由具體的HandlerAdapter對Handler進行具體的調用。
5、Handler對數據處理完成以后將返回一個ModelAndView()對象給DispatcherServlet。
6、Handler返回的ModelAndView()只是一個邏輯視圖并不是一個正式的視圖,DispatcherSevlet通過ViewResolver將邏輯視圖轉化為真正的視圖View。
7、Dispatcher通過model解析出ModelAndView()中的參數進行解析最終展現出完整的view并返回給客戶端。
工作機制是什么
接著對于(二)的補充:主要是小結下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 | /** * Return the HandlerExecutionChain for this request. * <p>Tries all handler mappings in order. * @param request current HTTP request * @return the HandlerExecutionChain, or <code>null if no handler could be found */ 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/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://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的工作原理和機制以及配置這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。