Spring MVC 3.0.5+Spring 3.0.5+MyBatis3.0.4全註解實例詳解(四)


    這一章大象將詳細分析web層代碼,以及使用Spring MVC的註解及其用法和其它相關知識來實現控制器功能。
    之前在使用Struts2實現MVC的註解時,是藉助struts2-convention這個插件,如今我們使用Spring自帶的spring-webmvc組件來實現同樣的功能,而且比之以前更簡單。另外,還省掉了整合兩個框架帶來的不穩定因素。
    對於Spring MVC框架,我主要講一下它的常用註解,再結合一些示例進行說明,方便大家能夠快速理解。
    一、Spring MVC常用註解說明
    @Controller
    在類上面定義,表明該類爲控制器,返回字符串與redirect:xxx
    @RequestMapping
    類或方法上面使用此註解,設置URL訪問地址。它有兩個屬性,value指定訪問路徑,method指定指定請求方式,請求方式在RequestMethod這個類中,全部以常量形式定義,它默認使用GET請求。
    @RequestParam
    指定Request請求參數,在方法參數中定義,相當於傳統的request.getParameter()。
    @PathVariable
    獲取URL訪問路徑變量,這是Spring MVC 3.0框架才加入的特性,基於RESTful風格的URL訪問路徑。
    @ModelAttribute
全局式的方法,在一組URL訪問路徑中,每次都會執行,方法返回結果保存在module會話中。
    @Service
    在類上面定義,指定被註解的類是業務邏輯組件,如果不指定具體的Bean ID,則採用默認命名方式,即類名的首字母小寫。之前在SSH2中,大象曾對Dao組件使用@Repository,本例只有業務層,所以就只用@Service註解。
    @Autowired
    IoC自動注入功能,替換以前的set寫法,在SSH2中就已經開始使用了。
    @Qualifier
    對同一接口類有不同實現指定具體的實現類。
    @ResponseBody
    同樣定義在方法上,Ajax調用聲明,指定方法返回結果爲Ajax回調函數結果。這是Spring MVC 3.0框架中增加的一個新特性。
    @InitBinder
    初始化數據綁定與類型轉換,將傳入的參數轉換爲自定義類型,或者對參數進行自定義處理。
    二、示例
    
    @RequestMapping在類名上面定義,相當於指定的URL是此控制器內的所有其它訪問路徑的父路徑。如果在某個方法上面定義@RequestMapping註解,則相對於父路徑來說,是其子路徑。如果不定義value值,那麼按父路徑訪問就會被默認執行。但請注意,默認的訪問方式只能有一個。
    對於UserController的list方法REST訪問URL爲http://localhost:8080/ssm3/user,而且它同時接收GET和POST兩種請求。另外,Spring MVC 3.0有一個很靈活的特性,可以自定義方法參數。看看list方法,我設定了兩個參數,一個Model,一個User對象。Model是用來渲染數據,生成頁面用的。相當於request.setAttribute,你可以這樣理解,但不能就這樣認爲,Model以及另一個ModelMap,都是作爲視圖模型傳遞參數的,它們的作用域爲request。除此之外,你還可以定義HttpServletRequest、HttpServletResponse等等各種各樣的參數。
如果一個類還要定義其它資源訪問怎麼辦呢?請看下面的RoleController
    
    在RoleController上定義了全局路徑/role,這樣一來,對於和角色相關的資源都會以/role開頭,比如創建角色/role/new;編輯角色/role/edit/{id}等等。
    上圖edit方法中的{id}寫法,就是RESTful URL風格,與@PathVariable搭配來一起實現該功能。它表示所請求的URL中,可以將變量值作爲參數進行動態的傳遞。例如:http://localhost:8080/ssm3/role/edit/1,另外,除了可以用數字,還可以用字符串,還可以多定義幾個變量:/role/edit/{id}/{type}等等。
    每個方法的返回值,其實都對應着一個結果頁面,這一點和struts2-convention這個插件很相像。本例使用FreeMarker模板引擎作爲展示層,頁面的後綴爲.html,頁面中除了標準的HTML之外,其餘的數據填充,條件判斷之類,都要用到FreeMarker指令。
    對於save方法返回值寫法表示的是重定向,相當於執行http://localhost:8080/ssm3/role,而這個URL對應的其實就是RoleController這個類裏面list方法。如果要帶上參數之類的,一定要符合所定義的REST資源路徑纔可以。
    

    @ResponseBody用來標識Ajax方法調用,在上面這個方法中,用到了@RequestParam註解,它的作用就和request.getParameter("name")一樣。Spring MVC框架支持好幾種返回格式,例如:String/JSON/XML等等。不過以這種格式的字符串值形式返回是最簡便的一種方式,而且利用JavaScript解析也十分方便。頁面調用的時候請用jQuery的$.ajax()這種原生方式來定義,這種寫法不會出問題,也很靈活,而且其它幾種方式最終也是調用它來完成請求。
    

    對於擁有相同的一組訪問規則的URL,如果都需要獲得相同的數據,則使用@ModelAttribute註解。以RoleController爲例,上面這個註解與方法的含義,相當於是在它裏面所有的訪問路徑方法中都調用這個寫法:module.addAttribute(“allRoles”,roleService.getRoles())。也即,不管是訪問create還是edit,都會執行preperList,都會獲得allRoles這個List。
    
    註冊自定義類型編輯器,在
Spring MVC中,對於時間類型,框架不會自動幫你轉換綁定,需要你自己來定義屬性編輯器。除此之外,還可以對某些特殊字符進行轉義符處理,都可以放在@InitBinder註解的方法中進行。如果所有的Controller都需要註冊相同的屬性編輯器,則可以實現WebBindingInitializer接口,定義一個全局的屬性編輯器。
    三、在web容器中部署
    想要讓Spring MVC框架幫助我們完成工作,就需要在Web容器中配置好它
    
    DispatcherServlet是Spring MVC的核心,是處理一切請求轉發的核心控制器。大象曾在本系列的第二篇文章中就詳細描述了Spring MVC的流程結構,如果沒什麼印象的話請再去看看。
    Spring MVC有一個默認規則,Web容器啓動之後,會自動查找/WEB-INF/<servlet-name>.xml這個Spring類型的配置文件。如果想自定義配置文件路徑,就按上面的寫法,指定contextConfiglocation這個屬性,大象採用maven構建項目,所以servlet-context.xml這個配置文件放在resource目錄下。
    四、MVC配置
    Spring MVC 3.0對使用和配置作了較大的改進,除了提供註解來簡化控制器的開發之外,在配置文件上面也進行了簡化。
    
    基於Spring MVC註解的配置就是上面這兩行,還有一種更簡化的配置寫法是隻寫這一句:<mvc:annotation-driven />就可以了,Spring啓動的時候會自動註冊上面這兩個bean。爲什麼大象要在這裏顯示的註冊兩個bean呢?因爲,我們在真正使用的時候,一般來說,使用默認的方式滿足不了我們的系統或業務要求。比如攔截器,比如數據驗證,比如返回消息格式轉換等等一些自定義設置。他們都需要配置在這兩個bean裏面。因爲本例是用來作爲入門教程,所以這些東西都沒有加進來。
    DefaultAnnotationHandlerMapping這個類是將所有標註了@RequestMapping註解的Controller類,都放到了一個HandlerMapping對象中當有請求時,就在這個對象中進行查找是否有與之匹配的路徑,AnnotationMethodHandlerAdapter是管理所有@RequestMapping註解的方法。
    這部分的內容到這裏就講完了,下一篇將對本例使用的展示層FreeMarker進行一下簡單介紹。
    本文爲菠蘿大象原創,如要轉載請註明出處。http://bolo.blogjava.net/

發佈了21 篇原創文章 · 獲贊 3 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章