Spring MVC框架是一個開源的Java平臺,為開發強大的基於Java的Web應用程式提供全面的基礎架構支持非常容易和非常快速。
Spring框架最初由Rod Johnson撰寫,並於2003年6月根據Apache 2.0許可證首次發佈。
本教程是基於2015年3月發佈的Spring Framework版本4.1.6編寫的。
Spring web MVC框架提供了MVC(模型 - 視圖 - 控制器)架構和用於開發靈活和鬆散耦合的Web應用程式的組件。 MVC模式導致應用程式的不同方面(輸入邏輯,業務邏輯和UI邏輯)分離,同時提供這些元素之間的鬆散耦合。
- 模型(Model)封裝了應用程式數據,通常它們將由
POJO類組成。 - 視圖(View)負責渲染模型數據,一般來說它生成客戶端流覽器可以解釋HTML輸出。
- 控制器(Controller)負責處理用戶請求並構建適當的模型,並將其傳遞給視圖進行渲染。
DispatcherServlet組件類
Spring Web模型 - 視圖 - 控制器(MVC)框架是圍繞DispatcherServlet設計的,它處理所有的HTTP請求和回應。 Spring Web MVC DispatcherServlet的請求處理工作流如下圖所示:

以下是對應於到DispatcherServlet的傳入HTTP請求的事件順序:
- 在接收到HTTP請求後,
DispatcherServlet會查詢HandlerMapping以調用相應的Controller。 Controller接受請求並根據使用的GET或POST方法調用相應的服務方法。 服務方法將基於定義的業務邏輯設置模型數據,並將視圖名稱返回給DispatcherServlet。DispatcherServlet將從ViewResolver獲取請求的定義視圖。- 當視圖完成,
DispatcherServlet將模型數據傳遞到最終的視圖,並在流覽器上呈現。
所有上述組件,即: HandlerMapping,Controller和ViewResolver是WebApplicationContext的一部分,它是普通ApplicationContext的擴展,帶有Web應用程式所需的一些額外功能。
必需的配置
需要通過使用web.xml檔中的URL映射來映射希望DispatcherServlet處理的請求。 下麵是一個示例來顯示HelloWeb DispatcherServlet示例的聲明和映射:
<web-app id="WebApp_ID" version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>Spring MVC Application</display-name>
<servlet>
<servlet-name>HelloWeb</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>HelloWeb</servlet-name>
<url-pattern>*.jsp</url-pattern>
</servlet-mapping>
</web-app>
web.xml檔將保存Web應用程式的WebContent/WEB-INF目錄。在HelloWeb DispatcherServlet初始化時,框架將嘗試從位於應用程式的WebContent/WEB-INF目錄中的名為[servlet-name]-servlet.xml的檔加載應用程式上下文。在這個示例中,使用的檔將是HelloWeb-servlet.xml。
接下來,<servlet-mapping>標記指示哪些URL將由DispatcherServlet處理。 這裏所有以.jsp結尾的HTTP請求都將由HelloWeb DispatcherServlet處理。
如果不想使用默認檔案名為[servlet-name]-servlet.xml和默認位置為WebContent/WEB-INF,可以通過在web.xml檔中添加servlet偵聽器ContextLoaderListener來自定義此檔案名和位置 如下:
<web-app...>
<!-------- DispatcherServlet definition goes here----->
....
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/HelloWeb-servlet.xml</param-value>
</context-param>
<listener>
<listener-class>
org.springframework.web.context.ContextLoaderListener
</listener-class>
</listener>
</web-app>
現在來看看HelloWeb-servlet.xml檔的必需配置,放在Web應用程式的WebContent/WEB-INF目錄中:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package="com.zaixian" />
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
</beans>
以下是有關HelloWeb-servlet.xml檔的重點說明:
[servlet-name]-servlet.xml檔將用於創建定義的bean,它會覆蓋在全局範圍中使用相同名稱定義的任何bean的定義。<context:component-scan ...>標籤將用於啟動Spring MVC注釋掃描功能,允許使用@Controller和@RequestMapping等注釋。InternalResourceViewResolver將定義用於解析視圖名稱的規則。根據上面定義的規則,hello的邏輯視圖將委託給位於/WEB-INF/jsp/hello.jsp這個視圖來實現。
下一節將演示如何創建實際組件。即:控制器,模型和視圖。
定義控制器
DispatcherServlet將請求委派給控制器以執行特定於其的功能。 @Controller注釋指示特定類充當控制器的角色。@RequestMapping注釋用於將URL映射到整個類或特定處理程式方法。
@Controller
@RequestMapping("/hello")
public class HelloController{
@RequestMapping(method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
@Controller注釋將類定義為Spring MVC控制器。這裏@RequestMapping的第一個用法表示此控制器上的所有處理方法都與/hello路徑相關。 下一個注釋@RequestMapping(method = RequestMethod.GET)用於聲明printHello()方法作為控制器的默認服務方法來處理HTTP GET請求。可以定義另一個方法來處理同一URL的任何POST請求。
可以以另一種形式在上面的控制器中編寫,在@RequestMapping中添加其他屬性,如下所示:
@Controller
public class HelloController{
@RequestMapping(value = "/hello", method = RequestMethod.GET)
public String printHello(ModelMap model) {
model.addAttribute("message", "Hello Spring MVC Framework!");
return "hello";
}
}
value屬性指示處理程式方法映射到的URL,method屬性定義處理HTTP GET請求的服務方法。關於以上定義的控制器,需要注意以下幾點:
- 在服務方法中定義所需的業務邏輯。可以根據需要在此方法內調用其他方法。
- 基於定義的業務邏輯,將在此方法中創建一個模型。可以設置不同的模型屬性,這些屬性將被視圖訪問以呈現最終結果。此示例創建且有屬性“
message”的模型。 - 定義的服務方法可以返回一個
String,它包含要用於渲染模型的視圖的名稱。此示例將“hello”返回為邏輯視圖名稱。
創建JSP視圖
Spring MVC支持許多類型的視圖用於不同的表示技術。包括 - JSP,HTML,PDF,Excel工作表,XML,Velocity範本,XSLT,JSON,Atom 和 RSS 源,JasperReports等。但最常見的是使用JSPL編寫的JSP範本,這裏使用的是JSP範本,並在/WEB-INF/hello/hello.jsp中寫一個簡單的hello視圖:
<html>
<head>
<title>Hello Spring MVC</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
這裏${message}是在Controller中設置的屬性。可以在視圖中顯示多個屬性。
