@RequestMapping 參數(shù)說明
value定義處理方法的請求的 URL 地址。
method
定義處理方法的 http method 類型,如 GET、POST 等。
params
定義請求的 URL 中必須包含的參數(shù)。
headers
定義請求中 Request Headers 必須包含的參數(shù)。
@RequestMapping 的用法
@RequestMapping 有兩種標(biāo)注方式,一種是標(biāo)注在類級別上,一種是標(biāo)注在方法級別上。標(biāo)注在方法上時,value 表示訪問該方法的 URL 地址。標(biāo)注在類上時,value 相當(dāng)于一個命名空間,即訪問該 Controller 下的任一方法都需
要帶上這個命名空間。
ExampleController.java
@Controller
@RequestMapping("/example")
public class ExampleController {
@RequestMapping
public String execute(){
return "example_page";
}
@RequestMapping("/todo")
public String doSomething(){
return "example_todo_page";
}
}
/example.action@RequestMapping("/example")
public class ExampleController {
@RequestMapping
public String execute(){
return "example_page";
}
@RequestMapping("/todo")
public String doSomething(){
return "example_todo_page";
}
}
執(zhí)行的是 execute() 方法。execute() 方法的 @RequestMapping 注解缺省 value 值,在這種情況下,當(dāng)訪問命名空間時默認(rèn)執(zhí)行的是這個
方法。方法級別上的 @RequestMapping 標(biāo)注是必須的,否則方法無法被正確訪問。
/example/todo.action
執(zhí)行的是 doSomething() 方法。類級別上的 @RequestMapping 標(biāo)注不是必須的,在不寫的情況下,方法上定義的 URL 都是絕對地址,否則,
方法上定義的 URL 都是相對于它所在的 Controller 的。
@RequestMapping(method)
指定 method 的值
@RequestMapping(value = "/register", method = RequestMethod.GET)
public String register(){
return "example_register_page";
}
method 的值一旦指定,那么,處理方法就只對指定的 http method 類型的請求進(jìn)行處理。
public String register(){
return "example_register_page";
}
@RequestMapping(value = "/register", method = RequestMethod.GET)
public String register1(){
return "example_register_get_page";
}
@RequestMapping(value = "/register", method = RequestMethod.POST)
public String register2(){
return "example_register_post_page";
}
可以為多個方法映射相同的 URI,不同的 http method 類型,Spring MVC 根據(jù)請求的 method 類型是可以區(qū)分開這些方法的。public String register1(){
return "example_register_get_page";
}
@RequestMapping(value = "/register", method = RequestMethod.POST)
public String register2(){
return "example_register_post_page";
}
當(dāng) /example/register.action 是以 GET 的方式提交的時候,Spring MVC 調(diào)用 register1() 來處理請求;若是以 POST 的方式提交,
則調(diào) register2() 來處理提交的請求。
缺省 method 的值
@RequestMapping("/enter")
public String enter(){
return "example_enter_page";
}
method 若是缺省沒指定,并不是說它默認(rèn)只處理 GET 方式的請求,而是它可以處理任何方式的 http method 類型的請求。public String enter(){
return "example_enter_page";
}
指定 method 是為了細(xì)化映射 ( 縮小處理方法的映射范圍 ),在 method 沒有指定的情況下,它的映射范圍是最大的。
@RequestMapping(params)
與 method 相類似,作用是為了細(xì)化映射。只有當(dāng) URL 中包含與 params 值相匹配的參數(shù)的請求,處理方法才會被調(diào)用。@RequestMapping(value = "/find", params = "target")
public String find1(){
return "example_find1_page";
}
@RequestMapping(value = "/find", params = "!target")
public String find2(){
return "example_find2_page";
}
@RequestMapping(value = "/search", params = "target=product")
public String search1(){
return "example_search1_page";
}
@RequestMapping(value = "/search", params = "target!=product")
public String search2(){
return "example_search2_page";
}
find1()public String find1(){
return "example_find1_page";
}
@RequestMapping(value = "/find", params = "!target")
public String find2(){
return "example_find2_page";
}
@RequestMapping(value = "/search", params = "target=product")
public String search1(){
return "example_search1_page";
}
@RequestMapping(value = "/search", params = "target!=product")
public String search2(){
return "example_search2_page";
}
請求的 URL 中必須要有 target 參數(shù),才能夠到達(dá)此方法。如 /example/find.action?target 或 /example/find.action?target=x 等
find2()
請求的 URL 中必須不能有 target 參數(shù),才能夠到達(dá)此方法。如 /example/find.action 或 /example/find.action?q=x 等
search1()
請求的 URL 中必須要有 target=product 參數(shù),才能夠到達(dá)此方法。如 /example/search.action?target=product 等
search2()
請求的 URL 中必須不能有 target=product 參數(shù),才能夠到達(dá)此方法。如 /example/search.action?target=article 等
@RequestMapping(headers)
headers 的作用也是用于細(xì)化映射。只有當(dāng)請求的 Request Headers 中包含與 heanders 值相匹配的參數(shù),處理方法才會被調(diào)用。@RequestMapping(value = "/specify", headers = "accept=text/*")
public String specify(){
return "example_specify_page";
}
請求的 Request Headers 中 Accept 的值必須匹配 text/* ( 如 text/html ),方法才會被調(diào)用。
public String specify(){
return "example_specify_page";
}