SpringMVC中RequestMapping註解(作用、出現的位置、屬性)
RequestMapping註解
作用出現位置屬性
作用
用於建立請求 URL 和處理請求方法之間的對應關系。
出現位置
1.作用在類上:請求 URL 的第一級訪問目錄。此處不寫的話,就相當於應用的根目錄。寫的話需要以/開頭。
2.作用在方法上:請求 URL 的第二級訪問目錄。
控制器中部分代碼示例:
@Controller @RequestMapping(path = "/user") //第一級的訪問目錄 public class HelloController { @RequestMapping(path = "/hello") //第二級的訪問目錄 public String sayHello(){ System.out.println("Hello SpringMVC"); return "success"; } @RequestMapping(value = "/testRequestmapping") //第二級的訪問目錄 public String testRequestmapping(){ System.out.println("測試註解"); return "success"; } }
jsp中部分代碼示例:
<!-- 第一種訪問方式 --> <a href="${pageContext.request.contextPath}/user/hello">sayHello</a> <br/> <!-- 第二種訪問方式 --> <a href="user/testRequestmapping">測試註解</a>
需要註意的細節:
1.細節:路徑可以不編寫 / 表示應用的根目錄開始
2.細節:${ pageContext.request.contextPath }也可以省略不寫,但是路徑上不能寫 /
屬性
value: 用於指定請求的 URL。它和 path 屬性的作用是一樣的。
method: 用於指定請求的方式。
params: 用於指定限制請求參數的條件。它支持簡單的表達式。要求請求參數的 key 和 value 必須和配置的一模一樣。
例如:
params = {“username”},表示請求參數必須有 username
params = {“age!100”},表示請求參數中 age 不能是 100
headers: 用於指定限制請求消息頭的條件。
註意:以上四個屬性隻要出現 2 個或以上時,他們的關系是與的關系。
value或path 屬性的示例
上面出現位置的示例就是value或path 屬性的示例。
method 屬性的示例
控制器的部分代碼:
@RequestMapping(value="/saveAccount",method=RequestMethod.POST) public String saveAccount() { System.out.println("保存瞭賬戶"); return "success"; }
jsp的部分代碼:
<!-- 請求方式的示例 --> <a href="account/saveAccount">保存賬戶,get 請求</a> <br/> <form action="account/saveAccount" method="post"> <input type="submit" value="保存賬戶,post 請求"> </form>
註意:當使用 get 請求時即method="get"
,提示錯誤信息是 405,信息是方法不支持 get 方式請求。
params 屬性的示例
控制器的部分代碼:
@RequestMapping(value="/removeAccount",params= {"accountName","money>100"}) public String removeAccount() { System.out.println("刪除瞭賬戶"); return "success"; }
jsp的部分代碼:
<!-- 請求參數的示例 --> <a href="account/removeAccount?accountName=aaa&money>100">刪除賬戶,金額 100</a> <br/> <a href="account/removeAccount?accountName=aaa&money>150">刪除賬戶,金額 150</a>
註意:
當我們點擊第一個超鏈接時,可以訪問成功。
當我們點擊第二個超鏈接時,無法訪問。如下圖:
params鍵值對的情況以及headers屬性
還存在params = {"username=keafmd"}
鍵值對的情況:這個示例的意思就是不光要有username的屬性還要求值為Keafmd。
同時headers屬性也就是表示必須包含相應的請求頭才可以。
控制器的部分代碼:
@Controller @RequestMapping(path = "/user") public class HelloController { @RequestMapping(value = "/testRequestmapping",method = {RequestMethod.GET},params = {"username=keafmd"},headers = {"Accept"}) public String testRequestmapping(){ System.out.println("測試註解"); return "success"; } }
jsp的部分代碼:
<a href="user/testRequestmapping?username=keafmd">RequestMapping註解</a>
這樣就是可以成功訪問的。
以上就是SpringMVC中RequestMapping註解【作用、出現的位置、屬性】全部內容。
到此這篇關於SpringMVC中RequestMapping註解(作用、出現的位置、屬性)的文章就介紹到這瞭,更多相關SpringMVC中RequestMapping註解內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 關於RequestMapping註解的作用說明
- 基於SpringMVC @RequestMapping的參數和用法
- SpringMVC @RequestMapping註解詳解
- SpringMVC HttpMessageConverter報文信息轉換器
- SpringMVC RESTFul及REST架構風格介紹