欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring MVC 基于URL的映射規(guī)則(注解版)

 更新時間:2017年05月21日 14:09:38   作者:xingoo  
這篇文章主要介紹了Spring MVC 基于URL的映射規(guī)則(注解版) ,詳細的介紹了幾種方式,有興趣的可以了解一下

好幾天沒有跟進Spring MVC的學習了,之前看了點源碼都忘的差不多了。這次就跟著之前的問題,繼續(xù)總結(jié)下Spring MVC中的小知識。
url-pattern

如果看過前一篇入門的帖子,應(yīng)該了解到spring mvc在啟動前必須要在web.xml中配置servlet,這樣才能攔截到想要映射的url地址。

 <servlet>
  <servlet-name>SpringMVC</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <load-on-startup>1</load-on-startup>
</servlet>
  
<servlet-mapping>
  <servlet-name>SpringMVC</servlet-name>
  <url-pattern>*.html</url-pattern>
</servlet-mapping> 

其中servlet配置了servlet的實現(xiàn)類,而servlet-mapping則定義了spring mvc起作用的url模式,常見的配置有三種:

  1.  / 這個斜杠,表示攔截所有的url,如/test,/test.html
  2.  /* 這個模式包含/,可以多攔截以*.jsp結(jié)尾的url
  3.  *.xxx 這個攔截固定結(jié)尾的url,常見的如*.do,*.json等等

RequestMapping()

基于注解風格的Spring MVC就是通過這個方法來定義映射的url的,常使用的方式如下:

基于普通的url

這種是最簡單的url映射,可以接收到localhost:8080/contextName/hello這樣的請求

 @RequestMapping("/hello")
  public @ResponseBody String test() {
    return "hello!";
  } 

基于多個普通的url路徑

RequestMapping可以同時指定多個url,映射到同一個應(yīng)答邏輯中:

 //普通的url路徑映射
  @RequestMapping(value={"/multi1","/multi2","/test/multi"})
  public @ResponseBody String multiUrl() {
    return "test multi url";
  } 

基于路徑變量的URL映射

這種URL映射可以直接在路徑上指定變量,通過@PathVariable可以獲得對象。

   //基本的URL模板映射
  @RequestMapping(value="/user1/{name}")
  public @ResponseBody String basicUrl1(@PathVariable String name){
    return "hello"+name;
  }
  @RequestMapping(value="/user2/{name}/test")
  public @ResponseBody String basicUrl2(@PathVariable String name){
    return "hello"+name+"test";
  }
  @RequestMapping(value="/user1/{name}/test/{age}")
  public @ResponseBody String basicUrl3(@PathVariable String name,@PathVariable int age){
    return "hello"+name+" age"+age;
  } 

基于通配風格的url映射

第一種

   @RequestMapping(value="/ant1?")
  public @ResponseBody String ant1(){
    return "ant1?";
  } 

支持下面風格:

 localhost:8080/context/ant12 或者localhost:8080/context/ant1a

第二種:

   @RequestMapping(value="/ant2*")
  public @ResponseBody String ant2(){
    return "ant2*";
  } 

支持下面風格:

localhost:8080/context/ant2aaaa 或者localhost:8080/context/ant2

第三種

 @RequestMapping(value="/ant3/*")
  public @ResponseBody String ant3(){
    return "ant3/*";
  } 

支持下面風格:

localhost:8080/context/ant3/aaaa 或者localhost:8080/context/ant3/123

第四種:

   @RequestMapping(value="/ant4/**")
  public @ResponseBody String ant4(){
    return "ant4/**";
  }

支持下面風格

 localhost:8080/context/ant4/ 或者localhost:8080/context/ant4/aaa 或者localhost:8080/context/ant4/aaa/123

混用統(tǒng)配和路徑變量

  //混用
  @RequestMapping(value="/ant5/**/{name}")
  public @ResponseBody String ant5(@PathVariable String name){
    return "ant+url "+name;
  } 

它能匹配

localhost:8080/context/ant5/123 或者localhost:8080/context/ant5/aaa/123 或者localhost:8080/context/ant5/aaa/123/test

最后一個會被當做name值

基于正則的url映射

這個比較有意思,它支持{名稱:正則表達式}的寫法,以另一種風格限制url的映射。

   //正則表達式
  @RequestMapping(value="/student/{name:\\w+}-{age:\\d+}")
  public @ResponseBody String regUrl(@PathVariable String name,@PathVariable int age){
    return "name:"+name+" age:"+age;
  } 

例如上面的URL就只能匹配如:

localhost:8080/context/student/wangwu-33 或者localhost:8080/context/student/zhao4-22

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論