標籤: springmvccss
[TOC]html
本文介紹RESTful的概念,並經過一個小例子展現如何編寫RESTful風格的controller和配置前端控制器,最後展現靜態資源的解析前端
首先附上兩篇博客連接java
RESTful架構,就是目前最流行的一種互聯網軟件架構。它結構清晰、符合標準、易於理解、擴展方便,因此正獲得愈來愈多網站的採用。python
RESTful(即Representational State Transfer的縮寫)實際上是一個開發理念,是對http的很好的詮釋。jquery
1.對url進行規範,寫RESTful格式的urlgit
http://...../queryItems.action?id=001&type=T01
http://..../items/001
特色:url簡潔,將參數經過url傳到服務端github
2.http的方法規範web
無論是刪除、添加、更新,等等。使用url是一致的,若是進行刪除,須要設置http的方法爲delete,其餘同理。spring
後臺controller方法:判斷http方法,若是是delete執行刪除,若是是post執行添加。
3.對http的contentType規範
請求時指定contentType,要json數據,設置成json格式的type。
查詢商品信息,返回json數據。
定義方法,進行url映射使用REST風格的url,將查詢商品信息的id傳入controller .
輸出json使用@ResponseBody
將java對象輸出json。
//查詢商品信息,輸出json //itemsView/{id}裏邊的{id}表示佔位符,經過@PathVariable獲取佔位符中的參數, //@PathVariable中名稱要和佔位符一致,形參名無需和其一致 //若是佔位符中的名稱和形參名一致,在@PathVariable能夠不指定名稱 @RequestMapping("/itemsView/{id}") public @ResponseBody ItemsCustom itemsView(@PathVariable("id") Integer items_id)throws Exception{ //調用service查詢商品信息 ItemsCustom itemsCustom = itemsService.findItemsById(items_id); return itemsCustom; }
@RequestMapping(value="/ itemsView/{id}")
:{×××}
佔位符,請求的URL能夠是/viewItems/1
或/viewItems/2
,經過在方法中使用@PathVariable
獲取{×××}中的×××變量。@PathVariable
用於將請求URL中的模板變量映射到功能處理方法的參數上。
若是@RequestMapping
中表示爲/itemsView/{id}
,id和形參名稱一致,@PathVariable
不用指定名稱。
<!-- springmvc前端控制器,rest配置 --> <servlet> <servlet-name>springmvc_rest</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- contextConfigLocation配置springmvc加載的配置文件(配置處理器映射器、適配器等等) 若是不配置contextConfigLocation,默認加載的是/WEB-INF/servlet名稱-serlvet.xml(springmvc-servlet.xml) --> <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-parttern中指定/
,對靜態資源的解析會出現問題,報404錯誤。
在springmvc.xml中添加靜態資源解析方法。
<!-- 靜態資源解析 包括 :js、css、img、.. --> <mvc:resources location="/js/" mapping="/js/**"/>
這時訪問http://localhost:8080/ssm1/js/jquery-1.4.4.min.js
,能夠在瀏覽器中看到js的內容