本文研究的主要是SpringMVC對RESTfull的支持的相關內容,具體如下。
RESTful架構,就是目前流行的一種互聯網軟件架構。它結構清晰、符合標準、易於理解、擴展方便,所以正得到越來越多網站的採用。 RESTful架構對url進行規範,寫RESTful格式的url是什麼樣子的呢?我們一般請求的url是類似這樣子的:
http://...../xxx.action?id=001&type=aaa
而REST的url風格是什麼樣子呢?一般它類似於:
http://..../xxx/001
所以REST有個很明顯的特點:使url變得簡潔,將參數通過url傳到服務端。 springmvc也是支持這種REST風格的url的,我們定義一個controller來測試一下:
//查詢商品信息,輸出json,使用RESTful@RequestMapping("/itemsView/{id}")public @ResponseBody ItemsCustom itemsView(@PathVariable("id") Integer id) throws Exception { ItemsCustom itemsCustom = itemsService.findItemsById(id); return itemsCustom;} @ResponseBody是用來將itemsCustom轉成json的註解,而@PathVariable註解則是跟REST有關了, @RequestMapping(value=”/ itemsView/{id}”)中的{id}表示一個佔位符,那麼這裡面傳過來的值會傳到被@PathVariable標記的形參上,如果形參和占位符中的變量一樣的話,可以不用再註解中指定,否則註解中要指定這個佔位符中的變量(即id)。這樣的話,參數就可以通過url傳到形參中來了。
但是這樣還不行,還要在前端控制器中針對REST進行配置,如下:
<!-- 配置springmvc的前端控制器DispatcherServlet,REST配置--><servlet> <servlet-name>springmvc_rest</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/springmvc.xml</param-value> </init-param></servlet><servlet-mapping> <servlet-name>springmvc_rest</servlet-name> <url-pattern>/</url-pattern></servlet-mapping>
攔截的是所有的url(/),這個配置跟之前配置好的前端控制器是沒有衝突的,可以並存。經過這樣配置後,就可以在瀏覽器中輸入http://localhost:8080/SpringMVC_Study/itemsView/1來測試返回到瀏覽器的數據了,可以看到返回一串json數據。
但是有個問題,使用上面的配置後會攔截所有的url,那麼對靜態資源也會攔截,所以DispatcherServlet也會解析靜態資源,但是這樣的話就會出錯,所以我們要設置一下不讓它解析靜態資源。如:
<!-- 靜態資源解析,包括js,css,img... --><mvc:resources location="/js/" mapping="/js/**"></mvc:resources><mvc:resources location="/img/" mapping="/img/**"></mvc:resources>
如果還有其他靜態資源的話,也要設置一下,這樣就不會去解析靜態資源了,訪問靜態資源的時候就直接訪問即可。
以上就是本文關於淺談SpringMVC對RESTfull的支持的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!