天天看點

SpringMVC 入門

2016-08-31 19:58:32

簡單的介紹一下MVC:

模型-視圖-控制器(MVC)是一個衆所周知的以設計界面應用程式為基礎的設計模式。它主要通過分離模型、視圖及控制器在應用程式中的角色将業務邏輯從界面中解耦。

通過政策接口,Spring 架構是高度可配置的,而且包含多種視圖技術,例如 JavaServer Pages(JSP)技術、Velocity、Tiles、iText和POI。Spring MVC 架構并不知道使用的視圖,是以不會強迫您隻使用 JSP 技術。Spring MVC 分離了控制器、模型對象、過濾器以及處理程式對象的角色,這種分離讓它們更容易進行定制。

Dispatcher Servlet(Spring控制器)

在最簡單的Spring MVC應用程式中,控制器是唯一的你需要在Java web部署描述檔案(即web.xml檔案)中配置的Servlet。Spring MVC控制器 ——通常稱作Dispatcher Servlet,實作了前端控制器設計模式。并且每個web請求必須通過它以便它能夠管理整個請求的生命周期。

當一個web請求發送到Spring MVC應用程式,dispatcher servlet首先接收請求。然後它組織那些在Spring web應用程式上下文配置的(例如實際請求處理控制器和視圖解析器)或者使用注解配置的元件,所有的這些都需要處理該請求

SpringMVC 入門

整個處理過程從一個HTTP請求開始:

1.Tomcat在啟動時加載解析web.xml,找到spring mvc的前端總控制器DispatcherServlet,并且通過DispatcherServlet來加載相關的配置檔案資訊。

2.DispatcherServlet接收到用戶端請求,找到對應HandlerMapping,根據映射規則,找到對應的處理器(Handler)。

3.調用相應處理器中的處理方法,處理該請求後,會傳回一個ModelAndView。

4.DispatcherServlet根據得到的ModelAndView中的視圖對象,找到一個合适的ViewResolver(視圖解析器),根據視圖解析器的配置,DispatcherServlet将要顯示的資料傳給對應的視圖,最後顯示給使用者。

1, 項目的結構圖:

SpringMVC 入門

2, 在pom.xml的引入相關的jar

<dependency>

     <groupId>org.springframework</groupId>

     <artifactId>spring-webmvc</artifactId>

     <version>4.0.0.RELEASE</version>

 </dependency>

3, 在web.xml裡配置

<servlet>

   <servlet-name>springMVC</servlet-name>

   <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

   <load-on-startup>1</load-on-startup>

  </servlet>

  <servlet-mapping>

   <url-pattern>/</url-pattern>

  </servlet-mapping>

4, 導入springMVC-sevlet.xml

<!-- 配置controller注解 -->

  <context:component-scan base-package="com.bw.controller" />

  <!-- 驅動 -->

  <mvc:annotation-driven />

  <!-- 視圖解析器 -->

  <bean id="ViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver" >

   <property name="prefix"><value>/WEB-INF/view/</value></property>

   <property name="suffix"><value>.jsp</value></property>

  </bean>

5, 寫一個類TestController

package com.bw.controller;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.web.bind.annotation.RequestMapping;

@Controller

public class TestController {

    @RequestMapping("StudentTest.do")

    public String getStudentTest(Model model){

       model.addAttribute("name", "hello");

       return "test";

    }

}

6, 編寫jsp頁面

SpringMVC 入門

7, 進行測試

SpringMVC 入門

這張是我從網上搜集的springMVC詳細運作流程圖:

SpringMVC 入門

springMVC常用的注解:

@Controller 負責注冊一個bean 到spring 上下文中,bean 的ID 預設為類名稱開頭字母小寫,你也可以自己指定,如下

1:

public class TestController {} 

2:           

@Controller("tmpController")

public class TestController {}

@RequestMapping

1.@RequestMapping用來定義通路的URL,你可以為整個類定義一個

@RequestMapping,或者為每個方法指定一個。

把@RequestMapping放在類級别上,這可令它與方法級别上的

@RequestMapping注解協同工作,取得縮小選擇範圍的效果。

例如:

@RequestMapping("/test")

則,該類下的所有通路路徑都在/test之下。

2.将@RequestMapping用于整個類不是必須的,如果沒有配置,所有的方法的通路路徑配置将是完全獨立的,沒有任何關聯。

3.完整的參數項為:@RequestMapping(value="",method ={"",""},headers={},params={"",""}),各參數說明如下:

value :String[] 設定通路位址

method: RequestMethod[]設定通路方式,字元數組,檢視RequestMethod類,包括GET, HEAD, POST, PUT, DELETE, OPTIONS, TRACE,常用

RequestMethod.GET,RequestMethod.POST

headers:String[] headers一般結合method = RequestMethod.POST使用

params: String[] 通路參數設定,字元數組 例如:userId=id

4.value的配置還可以采用模版變量的形式 ,例如:@RequestMapping(value="/owners/{ownerId}", method=RequestMethod.GET),這點将在介紹@PathVariable中詳細說明。

5.@RequestMapping params的補充說明,你可以通過設定參數條件來限制通路位址,例如params="myParam=myValue"表達式,通路位址中參數隻有包含了該規定的值"myParam=myValue"才能比對得上,類似"myParam"之類的表達式也是支援的,表示目前請求的位址必須有該參數(參數的值可以是任意),"!myParam"之類的表達式表明目前請求的位址不能包含具體指定的參數"myParam"。

6.有一點需要注意的,如果為類定義了通路位址為*.do,*.html之類的,則在方法級的@RequestMapping,不能再定義value值,否則會報錯,例如Java代碼 

@RequestMapping("/bbs.do") 

public class BbsController { 

    @RequestMapping(params = "method=getList") 

    public String getList() { 

     return "list"; 

    } 

@RequestMapping(value= "/spList") 

public String getSpecialList() { 

     return "splist"; 

}  

如上例:/bbs.do?method=getList 可以通路到方法getList() ;而通路/bbs.do/spList則會報錯.

@PathVariable

1.@PathVariable用于方法中的參數,表示方法參數綁定到位址URL的模闆變量。

Java代碼 

@RequestMapping(value="/owners/{ownerId}",

method=RequestMethod.GET) 

public String findOwner(@PathVariable String ownerId, Model

model) { 

  Owner owner = ownerService.findOwner(ownerId);   

  model.addAttribute("owner", owner);   

  return "displayOwner"; 

2.@PathVariable用于位址欄使用{xxx}模版變量時使用。如果@RequestMapping沒有定義類似"/{ownerId}" ,這種變量,則使用在方法中@PathVariable會報錯。 

@ModelAttribute

1.應用于方法參數,參數可以在頁面直接擷取,相當于request.setAttribute(,)

2.應用于方法,将任何一個擁有傳回值的方法标注上 @ModelAttribute,使其傳回值将會進入到模型對象的屬性清單中

3.應用于方法參數時@ModelAttribute("xx"),須關聯到Object的資料類型,基本資料類型 如:int,String不起作用

@ModelAttribute("items")//<——①向模型對象中添加一個名為items的屬性 

public List<String> populateItems() { 

        List<String> lists = new ArrayList<String>(); 

        lists.add("item1"); 

        lists.add("item2"); 

        return lists; 

@RequestMapping(params = "method=listAllBoard") 

public String listAllBoard(@ModelAttribute("currUser")User user,

ModelMap model) { 

        bbtForumService.getAllBoard(); 

        //<——②在此通路模型中的items屬性 

        System.out.println("model.items:" + ((List<String>)

model.get("items")).size()); 

        return "listBoard"; 

在 ① 處,通過使用 @ModelAttribute 注解,populateItem() 方法将在任何請求處理方法執行前調用,Spring MVC 會将該方法傳回值以“items”為名放入到隐含的模型對象屬性清單中。是以在 ② 處,我們就可以通過 ModelMap 入參通路到 items 屬性,當執行 listAllBoard() 請求處理方法時,② 處将在控制台列印出“model.items:2”的資訊。當然我們也可以在請求的視圖中通路到模型對象中的 items 屬性。

@ResponseBody

這個注解可以直接放在方法上,表示傳回類型将會直接作為HTTP響應位元組流輸出(不被放置在Model,也不被攔截為視圖頁面名稱)。可以用于ajax。

@RequestParam

@RequestParam是一個可選參數,例如:@RequestParam("id") 注解,是以它将和URL所帶參數 id進行綁定

如果入參是基本資料類型(如 int、long、float 等),URL 請求參數中一定要有對應的參數,否則将抛出org.springframework.web.util.NestedServletException 異常,提示無法将 null 轉換為基本資料類型. 

@RequestParam包含3個配置 @RequestParam(required = ,value="", defaultValue = "")

required :參數是否必須,boolean類型,可選項,預設為true

value: 傳遞的參數名稱,String類型,可選項,如果有值,對應到設定方法的參數

defaultValue:String類型,參數沒有傳遞時為參數預設指定的值

@SessionAttributes

session管理

Spring 允許我們有選擇地指定 ModelMap 中的哪些屬性需要轉存到 session 中,以便下一個請求屬對應的 ModelMap 的屬性清單中還能通路到這些屬性。這一功能是通過類定義處标注 @SessionAttributes 注解來實作的。@SessionAttributes 隻能聲明在類上,而不能聲明在方法上。

例如

@SessionAttributes("currUser") // 将ModelMap 中屬性名為currUser 的屬性

@SessionAttributes({"attr1","attr2"})

@SessionAttributes(types = User.class)

@SessionAttributes(types = {User.class,Dept.class})

@SessionAttributes(types = {User.class,Dept.class},value={"attr1","attr2"})

@CookieValue 擷取cookie資訊

@RequestHeader 擷取請求的頭部資訊

繼續閱讀