您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Spring集成Web環境與SpringMVC組件擴展使用的方法”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Spring集成Web環境與SpringMVC組件擴展使用的方法”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
實際開發中,我們通常需要編寫多個Web相關的Servlet的時候,如下
package com.kang.service; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; @WebServlet("/userServlet") public class UserServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { ApplicationContext app = new ClassPathXmlApplicationContext("applicatonContext.xml"); UserService userService = (UserService) app.getBean("userService"); userService.save(); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); } }
這里就會出現一個問題,spring的xml文件只需要加載一次即可,并不需要每啟動一個Servlet就加載一個xml文件,應用上下文的對象也被創建多次,這明顯是一個不太好的弊端
這時候spring以及給我們封裝好一個工具類用于返回加載這個xml配置文件的ApplicationContext對象
引入:ServletContext
ServletContext官方叫servlet上下文。服務器會為每一個工程創建一個對象,這個對象就是ServletContext對象。這個對象全局唯一,而且工程內部的所有servlet都共享這個對象。所以叫全局應用程序共享對象。
作用:
是一個域對象
可以讀取全局配置參數
可以搜索當前工程目錄下面的資源文件
可以獲取當前工程名字(了解)
首先在web.xml配置全局參數(spring配置文件名稱)和spring監聽器(用于服務開始的時候加載springxml文件)
通過這個方法來減少spring配置文件的加載次數,從而提高程序的加載速度
使用步驟:
在web.xml配置ContextLoaderListener監聽器(導入spring-web坐標)
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.0.5.RELEASE</version> </dependency>
使用WebApplicationContextUtils獲得應用上下文對象ApplicationContext
<!--web.xml--> <!--全局參數:配置spring的xml配置文件名字--> <display-name>Archetype Created Web Application</display-name> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicatonContext.xml</param-value> </context-param> <!--Spring監聽器--> <listener> <listener-class>org.springframework.web.context.ContextCleanupListener</listener-class> </listener>
package com.kang.service; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.web.context.WebApplicationContext; import org.springframework.web.context.support.WebApplicationContextUtils; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; @WebServlet("/userServlet") public class UserServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //獲取ServletContext對象,用于讀取全局參數 ServletContext servletContext = request.getServletContext(); //獲取監聽器返回的WebApplicationContext對象 WebApplicationContext app = WebApplicationContextUtils.getWebApplicationContext(servletContext); UserService userService = app.getBean(UserService.class); userService.save(); } @Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); } }
SpringMVC 是一種基于 Java 的實現 MVC 設計模型的請求驅動類型的輕量級 Web 框架,屬于 SpringFrameWork 的后續產品,已經融合在 Spring Web Flow 中。
它通過一套注解,讓一個簡單的 Java 類成為處理請求的控制器,而無須實現任何接口。同時 它還支持 RESTful 編程風格的請求。
開發步驟
導入SpringMVC相關坐標
<!--springMVC--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.0.5.RELEASE</version> </dependency>
配置SpringMVC核心控制器DispathcerServlet
<!--springMVC的前端控制器--> <servlet> <servlet-name>DispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--導入springmcv核心配置文件--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!--映射配置--> <servlet-mapping> <servlet-name>DispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
創建Controller類和視圖頁面
創建一個Controller包,編寫QuickController類
使用注解配置Controller類中業務方法的映射地址
@Controller //使用在web層類上用于實例化Bean(放到容器當中) public class QuickController { @RequestMapping("/quick") //請求映射 public String quickMethod(){ System.out.println("quickMethod running......."); //return:要跳轉的視圖 return "quick.jsp"; } }
配置SpringMVC核心文件 spring-mvc.xml
將下面代碼放在web.xml的前端控制器的servlet標簽中
<!--導入springmcv核心配置文件--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param>
<!--spring-mvc的配置文件(該注釋要刪)--> <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation=" 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"> <!--包掃描--> <context:component-scan base-package="com.kang.controller"/> </beans>
訪問
http://localhost:8080/SpringMVC/quick
就可以看見控制臺輸出
quickMethod running.......
訪問流程如下
在瀏覽器訪問地址
然后tomcat尋找前端控制器,這里前端控制器配置缺省
然后前端控制器根據輸入的url找到對應的Controller映射的“/quick”,從而返回視圖
瀏覽器請求訪問某一個資源到視圖的展示,并不是靠一個前端控制器來實現的
用戶發送請求到前端控制器DispatcherServlet
DispatcherServlet收到請求調用HandlerMapping處理器映射器。
HandlerMapping處理器映射器對請求進行解析,找到具體的處理器(可以根據xml配置、注解進行查找),生成處理器對象及處理器攔截器(如果 有則生成)一并返回(一串資源的地址)給DispatcherServlet
DispatcherServlet調用HandlerAdapter處理器適配器
HandlerAdapter經過適配調用具體的處理器(Controller,也叫后端控制器)。
Controller執行完成返回ModelAndView。
HandlerAdapter將controller執行結果ModelAndView返回給DispatcherServlet。
DispatcherServlet將ModelAndView傳給ViewReslover視圖解析器。
ViewReslover解析后返回具體View。
DispatcherServlet根據View進行渲染視圖(即將模型數據填充至視圖中)。DispatcherServlet響應用戶。
前端控制器:DispatcherServlet
用戶請求到達前端控制器,它就相當于 MVC 模式中的 C,DispatcherServlet 是整個流程控制的中心,由 它調用其它組件處理用戶的請求,DispatcherServlet 的存在降低了組件之間的耦合性。
處理器映射器:HandlerMapping
HandlerMapping 負責根據用戶請求找到 Handler 即處理器,SpringMVC 提供了不同的映射器實現不同的 映射方式,例如:配置文件方式,實現接口方式,注解方式等。
處理器適配器:HandlerAdapter
通過 HandlerAdapter 對處理器進行執行,這是適配器模式的應用,通過擴展適配器可以對更多類型的處理 器進行執行
處理器:Handler
它就是我們開發中要編寫的具體業務控制器。由 DispatcherServlet 把用戶請求轉發到 Handler。由 Handler 對具體的用戶請求進行處理。
視圖解析器:View Resolver
View Resolver 負責將處理結果生成 View 視圖,View Resolver 首先根據邏輯視圖名解析成物理視圖名,即 具體的頁面地址,再生成 View 視圖對象,最后對 View 進行渲染將處理結果通過頁面展示給用戶。
視圖:View
SpringMVC 框架提供了很多的 View 視圖類型的支持,包括:jstlView、freemarkerView、pdfView等。最 常用的視圖就是 jsp。一般情況下需要通過頁面標簽或頁面模版技術將模型數據通過頁面展示給用戶,需要由程 序員根據業務需求開發具體的頁面
@RequestMapping 作用:用于建立請求 URL 和處理請求方法之間的對應關系(加的位置不同,意義也不同)
類上,請求URL 的第一級訪問目錄。此處不寫的話,就相當于應用的根目錄
@Controller //使用在web層類上用于實例化Bean(放到容器當中) @RequestMapping("/user") public class QuickController { @RequestMapping("/quick") //請求映射 public String quickMethod(){ System.out.println("quickMethod running......."); //return:要跳轉的視圖 //要加一個/表示當前web目錄下 return "/quick.jsp"; } } //訪問地址變為:http://localhost:8080/SpringMVC/user/quick
方法上,請求 URL 的第二級訪問目錄,與類上的使用@ReqquestMapping標注的一級目錄一起組成訪問虛擬路徑
其中@RequestMapping 注解還有很多屬性,可以用來規定請求方式等等
相關屬性:
value:用于指定請求的URL。它和path屬性的作用是一樣的
method:用于指定請求的方式
params:用于指定限制請求參數的條件。它支持簡單的表達式。要求請求參數的key和value必須和配置的一模一樣 例如:
params = {“accountName”},表示請求參數必須有accountName
params = {“moeny!100”},表示請求參數中money不能是100
@Controller //使用在web層類上用于實例化Bean(放到容器當中) @RequestMapping("/user") public class QuickController { @RequestMapping(value = "/quick", method = RequestMethod.GET, params = {"username"}) //請求映射 public String quickMethod(){ System.out.println("quickMethod running......."); //return:要跳轉的視圖 //要加一個/表示當前web目錄下 return "/quick.jsp"; } } //訪問地址:http://localhost:8080/SpringMVC/user/quick?username=xxx
在使用@Controller等注解解析之后,都要進行組件掃描
<context:component-scan base-package="com.kang.controller"/>
這里是規定了掃描的包名,除此之外,還可以規定掃描哪些注解
<context:component-scan base-package="com.kang.controller"> <!--掃描com.kang.controller包下的Controller注解--> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan>
在前面的Controller返回了"quick.jsp"視圖,若是不想編寫
jsp后綴,我們可以通過視圖解析器來修改視圖前后綴
<!--配置內部資源視圖解析器--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!--配置前綴--> <property name="prefix" value="/jsp/"></property> <!--配置后綴--> <property name="suffix" value=".jsp"></property> </bean>
除此之外,還可以規定視圖的顯示形式,是請求轉發還是重定向都可以
只需要在返回的字符串加:
forward:轉發
redirect:重定向
讀到這里,這篇“Spring集成Web環境與SpringMVC組件擴展使用的方法”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。