Spring MVC簡介
Spring MVC框架是有一個MVC框架,通過實現(xiàn)Model-View-Controller模式來很好地將數(shù)據(jù)、業(yè)務(wù)與展現(xiàn)進(jìn)行分離。從這樣一個角度來說,Spring MVC和Struts、Struts2非常類似。Spring MVC的設(shè)計是圍繞DispatcherServlet展開的,DispatcherServlet負(fù)責(zé)將請求派發(fā)到特定的handler。通過可配置的handler mappings、view resolution、locale以及theme resolution來處理請求并且轉(zhuǎn)到對應(yīng)的視圖。Spring MVC請求處理的整體流程如圖:
Spring3.x中定義一個控制器類,必須以@Controller注解標(biāo)記。當(dāng)控制器類接收到一個請求時,它會在自己內(nèi)部尋找一個合適的處理方法來處理請求。使用@RequestMapping注解將方法映射到一些請求上,以便讓該方法處理那些請求。這種方法就像一般的類中的方法,方法名參數(shù)列表和返回值并不像Struts2之類的框架有很強(qiáng)的限制。方法參數(shù)列表具體以及返回值具體都有哪些,這里先不細(xì)說。這篇博客的目的在于簡單介紹如何快速上手使用Spring MVC框架。
控制器在選擇好適合處理請求的方法時,傳入收到的請求(根據(jù)方法參數(shù)類型,可能以不同的類型傳入),并且調(diào)用該方法中的邏輯來進(jìn)行處理(也可以是調(diào)用Service來真正處理)。方法邏輯可能也會在參數(shù)中添加或者刪除數(shù)據(jù)。處理方法處理完之后,會委派給一個視圖,由該視圖來處理方法的返回值。處理程序的返回值并不代表視圖的具體實現(xiàn),可以只是String類型,代表視圖名,甚至是void(這時候Spring MVC可以根據(jù)方法名或者控制器名找默認(rèn)視圖)。也不需要擔(dān)心返回值只是視圖名稱的話,視圖拿不到要顯示的數(shù)據(jù)。因為方法參數(shù)對于視圖來說也是可以拿到的。比如說,如果處理方法以Map為參數(shù),那么這個Map對于視圖也是可以拿到的。
返回的視圖名稱會返回給DispatcherServlet,它會根據(jù)一個視圖解析器將視圖名稱解析為一個具體的視圖實現(xiàn)。這里說到的視圖解析器是一個實現(xiàn)了ViewResolver借口的Bean,它的任務(wù)就是返回一個視圖的具體實現(xiàn)(HTML、JSP、PDF等等)。
SpringMVC框架介紹
1) Spring MVC屬于SpringFrameWork的后續(xù)產(chǎn)品,已經(jīng)融合在Spring Web Flow里面。
Spring 框架提供了構(gòu)建 Web 應(yīng)用程序的全功能 MVC 模塊。使用 Spring 可插入的 MVC 架構(gòu),可以選擇是使用內(nèi)置的 Spring Web 框架還是 Struts 這樣的 Web 框架。通過策略接口,Spring 框架是高度可配置的,而且包含多種視圖技術(shù),例如 JavaServer Pages(JSP)技術(shù)、Velocity、Tiles、iText 和 POI。Spring MVC 框架并不知道使用的視圖,所以不會強(qiáng)迫您只使用 JSP 技術(shù)。
Spring MVC 分離了控制器、模型對象、分派器以及處理程序?qū)ο蟮慕巧?,這種分離讓它們更容易進(jìn)行定制。
2) Spring的MVC框架主要由DispatcherServlet、處理器映射、處理器(控制器)、視圖解析器、視圖組成。
SpringMVC原理圖
SpringMVC接口解釋
DispatcherServlet接口:
Spring提供的前端控制器,所有的請求都有經(jīng)過它來統(tǒng)一分發(fā)。在DispatcherServlet將請求分發(fā)給Spring Controller之前,需要借助于Spring提供的HandlerMapping定位到具體的Controller。
HandlerMapping接口:
能夠完成客戶請求到Controller映射。
Controller接口:
需要為并發(fā)用戶處理上述請求,因此實現(xiàn)Controller接口時,必須保證線程安全并且可重用。
Controller將處理用戶請求,這和Struts Action扮演的角色是一致的。一旦Controller處理完用戶請求,則返回ModelAndView對象給DispatcherServlet前端控制器,ModelAndView中包含了模型(Model)和視圖(View)。
從宏觀角度考慮,DispatcherServlet是整個Web應(yīng)用的控制器;從微觀考慮,Controller是單個Http請求處理過程中的控制器,而ModelAndView是Http請求過程中返回的模型(Model)和視圖(View)。
ViewResolver接口:
Spring提供的視圖解析器(ViewResolver)在Web應(yīng)用中查找View對象,從而將相應(yīng)結(jié)果渲染給客戶。
SpringMVC運行原理
1. 客戶端請求提交到DispatcherServlet
2. 由DispatcherServlet控制器查詢一個或多個HandlerMapping,找到處理請求的Controller
3. DispatcherServlet將請求提交到Controller
4. Controller調(diào)用業(yè)務(wù)邏輯處理后,返回ModelAndView
5. DispatcherServlet查詢一個或多個ViewResoler視圖解析器,找到ModelAndView指定的視圖
6. 視圖負(fù)責(zé)將結(jié)果顯示到客戶端
DispatcherServlet是整個Spring MVC的核心。它負(fù)責(zé)接收HTTP請求組織協(xié)調(diào)Spring MVC的各個組成部分。其主要工作有以下三項:
1. 截獲符合特定格式的URL請求。
2. 初始化DispatcherServlet上下文對應(yīng)的WebApplicationContext,并將其與業(yè)務(wù)層、持久化層的WebApplicationContext建立關(guān)聯(lián)。
3. 初始化Spring MVC的各個組成組件,并裝配到DispatcherServlet中。
具體實例可參考:http://blog.csdn.net/kkdelta/article/details/7274708
http://downpour.iteye.com/category/196182
SpringMVC 注解
@Controller 負(fù)責(zé)注冊一個bean 到spring 上下文中,bean 的ID 默認(rèn)為類名稱開頭字母小寫,你也可以自己指定,
如下 方法一: @Controller public class TestController {} 方法二: @Controller(“tmpController”) public class TestController {}
@RequestMapping
1.@RequestMapping用來定義訪問的URL,你可以為整個類定義一個
@RequestMapping,或者為每個方法指定一個。
把@RequestMapping放在類級別上,這可令它與方法級別上的@RequestMapping注解協(xié)同工作,取得縮小選擇范圍的效果。
例如:
@RequestMapping(“/test”)
public class TestController {}
則,該類下的所有訪問路徑都在/test之下。
2.將@RequestMapping用于整個類不是必須的,如果沒有配置,所有的方法的訪問路徑配置將是完全獨立的,沒有任何關(guān)聯(lián)。
3.完整的參數(shù)項為:@RequestMapping(value=“”,method ={“”,“”},headers={},params={“”,“”}),
各參數(shù)說明如下:
value :String[] 設(shè)置訪問地址
method: RequestMethod[]設(shè)置訪問方式,字符數(shù)組,查看RequestMethod類,包括GET, HEAD, POST, PUT, DELETE, OPTIONS, TRACE,常用
RequestMethod.GET,RequestMethod.POST
headers:String[] headers一般結(jié)合method = RequestMethod.POST使用
params: String[] 訪問參數(shù)設(shè)置,字符數(shù)組 例如:userId=id
4.value的配置還可以采用模版變量的形式 ,例如:@RequestMapping
?。╲alue=“/owners/{ownerId}”, method=RequestMethod.GET),這點將在介紹@PathVariable中詳細(xì)說明。
5.@RequestMapping params的補(bǔ)充說明,你可以通過設(shè)置參數(shù)條件來限制
訪問地址,例如param s=“myParam=myValue”表達(dá)式,訪問地址中參數(shù)只有
包含了該規(guī)定的值“myParam=myValue”才能匹配得上,類似“myParam”之類
的表達(dá)式也是支持的,表示當(dāng)前請求的地址必須有該參數(shù)(參數(shù)的值可以是
任意),“!myParam”之類的表達(dá)式表明當(dāng)前請求的地址不能包含具體指定的
參數(shù)“myParam”。
6.有一點需要注意的,如果為類定義了訪問地址為*.do,*.html之類的,則
在方法級的@RequestMapping,不能再定義value值,否則會報錯,例如
Java代碼
@RequestMapping(“/bbs.do”)
public class BbsController {
@RequestMapping(params = “method=getList”)
public String getList() {
return “l(fā)ist”;
}
@RequestMapping(value= “/spList”)
public String getSpecialList() {
return “splist”;
}
}
如上例:/bbs.do?method=getList 可以訪問到方法getList() ;而訪
問/bbs.do/spList則會報錯。
@PathVariable
1.@PathVariable用于方法中的參數(shù),表示方法參數(shù)綁定到地址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.應(yīng)用于方法參數(shù),參數(shù)可以在頁面直接獲取,相當(dāng)于
request.setAttribute(,)
2.應(yīng)用于方法,將任何一個擁有返回值的方法標(biāo)注上 @ModelAttribute,使
其返回值將會進(jìn)入到模型對象的屬性列表中。
3.應(yīng)用于方法參數(shù)時@ModelAttribute(“xx”),須關(guān)聯(lián)到Object的數(shù)據(jù)類型
,基本數(shù)據(jù)類型 如:int,String不起作用
例如:
Java代碼
@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 “l(fā)istBoard”;
}
在 ① 處,通過使用 @ModelAttribute 注解,populateItem() 方法將在
任何請求處理方法執(zhí)行前調(diào)用,Spring MVC 會將該方法返回值以“items
”為名放入到隱含的模型對象屬性列表中。
所以在 ② 處,我們就可以通過 ModelMap 入?yún)⒃L問到 items 屬性,當(dāng)執(zhí)
行 listAllBoard() 請求處理方法時,② 處將在控制臺打印
出“model.items:2”的信息。當(dāng)然我們也可以在請求的視圖中訪問到模型
對象中的 items 屬性。
@ResponseBody
這個注解可以直接放在方法上,表示返回類型將會直接作為HTTP響應(yīng)字節(jié)
流輸出(不被放置在Model,也不被攔截為視圖頁面名稱)??梢杂糜赼jax。
@RequestParam
@RequestParam是一個可選參數(shù),例如:@RequestParam(“id”) 注解,所以
它將和URL所帶參數(shù) id進(jìn)行綁定
如果入?yún)⑹腔緮?shù)據(jù)類型(如 int、long、float 等),URL 請求參數(shù)中
一定要有對應(yīng)的參數(shù),否則將拋出
org.springframework.web.util.NestedServletException 異常,提示無
法將 null 轉(zhuǎn)換為基本數(shù)據(jù)類型。
@RequestParam包含3個配置 @RequestParam(required = ,value=“”,
defaultValue = “”)
required :參數(shù)是否必須,boolean類型,可選項,默認(rèn)為true
value: 傳遞的參數(shù)名稱,String類型,可選項,如果有值,對應(yīng)到設(shè)置方
法的參數(shù)
defaultValue:String類型,參數(shù)沒有傳遞時為參數(shù)默認(rèn)指定的值
@SessionAttributes session管理
Spring 允許我們有選擇地指定 ModelMap 中的哪些屬性需要轉(zhuǎn)存到
session 中,以便下一個請求屬對應(yīng)的 ModelMap 的屬性列表中還能訪問
到這些屬性。這一功能是通過類定義處標(biāo)注 @SessionAttributes 注解來
實現(xiàn)的。@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 獲取請求的頭部信息
評論
查看更多