java中@requestMappling注解的使用
@RequestMapping注解的作用
從注解名稱上我們可以看到
@RequestMapping注解的作用就是將請(qǐng)求和處理請(qǐng)求的控制器方法關(guān)聯(lián)起來(lái),建立映射關(guān)系。
SpringMVC 接收到指定的請(qǐng)求,就會(huì)來(lái)找到在映射關(guān)系中對(duì)應(yīng)的控制器方法來(lái)處理這個(gè)請(qǐng)求。
@RequestMapping注解的位置
@RequestMapping標(biāo)識(shí)一個(gè)類:設(shè)置映射請(qǐng)求的請(qǐng)求路徑的初始信息(基礎(chǔ)信息)
@RequestMapping標(biāo)識(shí)一個(gè)方法:設(shè)置映射請(qǐng)求請(qǐng)求路徑的具體信息
controller控制層
處理首頁(yè)的控制層(標(biāo)識(shí)在方法上)
@Controller
public class ProtalController {
@RequestMapping("/")
public String protal(){
return "index";
}
}
標(biāo)識(shí)在類上和方法
@Controller
//標(biāo)記到類上,設(shè)置當(dāng)前請(qǐng)求映射的基礎(chǔ)信息,方法上是具體信息
@RequestMapping("/test")
public class TestRequestMapplingController {
// 控制器方法所配置的請(qǐng)求的請(qǐng)求路徑為/test/hello
@RequestMapping("/hello")
public String hello(){
return "success";
}
}
thymeleaf渲染頁(yè)面(index.html)
<body>
<h1>index.html</h1>
<a th:href="@{/hello}" rel="external nofollow" >測(cè)@RquestMappling標(biāo)識(shí)注解的位置</a>
</body>
跳轉(zhuǎn)的頁(yè)面)(success,html)
<body> <h1>跳轉(zhuǎn)成功</h1> </body>
@RequestMapping注解的value屬性
value屬性通過(guò)請(qǐng)求的請(qǐng)求地址匹配請(qǐng)求映射。
value屬性是一個(gè)字符串類型的數(shù)組,
即當(dāng)前瀏覽器所發(fā)送的請(qǐng)求路徑匹配value屬性中的任何一個(gè)值
則當(dāng)前請(qǐng)求就會(huì)被注解所標(biāo)識(shí)的方法進(jìn)行處理。
value屬性必須設(shè)置,至少通過(guò)請(qǐng)求地址匹配請(qǐng)求映射。
@Controller
public class TestRequestMapplingController {
@RequestMapping({"/hello","/second"})
public String hello(){
return "success";
}
}
@RequestMapping注解的method屬性
作用:@RequestMapping注解的method屬性是一個(gè)RequestMethod類型的 數(shù)組,表示該請(qǐng)求映射能夠匹配多種請(qǐng)求方式的請(qǐng)求。
規(guī)定控制器的方法在請(qǐng)求路徑匹配的情況下,當(dāng)前控制器方法處理請(qǐng)求的請(qǐng)求方式是什么?
當(dāng)前請(qǐng)求路徑和請(qǐng)求方式都能匹配,控制器方法才能處理這個(gè)請(qǐng)求。
注意:
通過(guò)請(qǐng)求的請(qǐng)求方式匹配請(qǐng)求。
當(dāng)前瀏覽器所發(fā)送的請(qǐng)求方式匹配method屬性中的任何一種請(qǐng)求方式,
則當(dāng)前請(qǐng)求就會(huì)被注解所標(biāo)識(shí)的方法進(jìn)行處理。
若瀏覽器所發(fā)送的請(qǐng)求的請(qǐng)求路徑和@RequestMapping注解value屬性匹配,
但是請(qǐng)求方式不匹配此時(shí),頁(yè)面報(bào)錯(cuò):405.....
get和post請(qǐng)求都可以匹配:method = {RequestMethod.GET,RequestMethod.POST}
@RequestMapping注解的method屬性通過(guò)請(qǐng)求的請(qǐng)求方式 (get或post) 匹配請(qǐng)求映射。
@RequestMapping(value = {"/hello","/second"},method = RequestMethod.GET )
public String hello(){
return "success";
}
@RequestMapping注解使用ant風(fēng)格路徑
?:表示任意的單個(gè)字符
注意:? 是當(dāng)前請(qǐng)求路徑中路徑和參數(shù)分割符,所以地址中 ?前面才是路徑,? 后面當(dāng)成請(qǐng)求參數(shù)
* :表示任意的0個(gè)或多個(gè)字符
** :表示任意層數(shù)的任意目錄
注意:在使用**時(shí),只能使用/**/xxx的方式
@RequestMapping("/a?a/test/ant")
public String testAnt(){
return "success";
}
thymeleaf渲染頁(yè)面
<a th:href="@{/aaa/test/ant}">測(cè)試測(cè)@RquestMappling注解支持ant風(fēng)格路徑</a>
@RequestMapping注解使用路徑中的占位符
原始方式:/deleteUser?id=1
rest方式:/user/delete/1
把傳輸服務(wù)器參數(shù)(例如下面的admin/1這兩個(gè)參數(shù))也作為路徑一部分,傳輸?shù)椒?wù)器中。
會(huì)把所有的內(nèi)容全部體現(xiàn)在路徑中,把id值傳過(guò)去就不用id和 ?
用原始方式是鍵值對(duì),用rest方式該如何獲???,
就需要使用路徑中的占位符和@PathVariable注解。
thymeleaf渲染
<a th:href="@{/test/rest/admin/1}">測(cè)試測(cè)@RquestMappling的value屬性的占位符</a>
controller控制器
// {id}:占位符
@RequestMapping("/test/rest/{username}/{id}")
public String testRest(@PathVariable("id") Integer id,@PathVariable("username") String username){
System.out.println("id:"+id+"username:"+username);
return "success";
}
即匹配到當(dāng)前請(qǐng)求映射,還要在控制器方法中獲取傳遞過(guò)去的請(qǐng)求參數(shù)
以前是name=value,現(xiàn)在只有value。
只需要在控制器方法里面獲取占位符id這個(gè)值,賦值到參數(shù)里面,
所以需要在@RequestMapping注解的value屬性中設(shè)置的路徑中,使用{xx}的方式表示路徑中的數(shù)據(jù),和通過(guò)@PathVariable注解將占位符所標(biāo)識(shí)的值和控制器方法的形參進(jìn)行綁定(也就是路徑中的變量 )。
到此這篇關(guān)于java中@requestMappling注解的使用的文章就介紹到這了,更多相關(guān)java @requestMappling注解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springcloud Zuul動(dòng)態(tài)路由的實(shí)現(xiàn)
這篇文章主要介紹了springcloud Zuul動(dòng)態(tài)路由的實(shí)現(xiàn),詳細(xì)的介紹了什么是Zuu及其動(dòng)態(tài)路由的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
Spring如何替換掉默認(rèn)common-logging.jar
這篇文章主要介紹了Spring如何替換掉默認(rèn)common-logging.jar,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
springboot的切面應(yīng)用方式(注解Aspect)
文章總結(jié):Spring?Boot提供了三種攔截器:Filter、Interceptor和Aspect,Filter主要用于內(nèi)容過(guò)濾和非登錄狀態(tài)的非法請(qǐng)求過(guò)濾,無(wú)法獲取Spring框架相關(guān)的信息,Interceptor可以在獲取請(qǐng)求類名、方法名的同時(shí),獲取請(qǐng)求參數(shù),但無(wú)法獲取參數(shù)值2024-11-11
java實(shí)現(xiàn)遠(yuǎn)程桌面的實(shí)例代碼
下面小編就為大家分享一篇java實(shí)現(xiàn)遠(yuǎn)程桌面的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
解析Java中的隊(duì)列和用LinkedList集合模擬隊(duì)列的方法
這篇文章主要介紹了解析Java中的隊(duì)列和用LinkedList集合模擬隊(duì)列的方法,相關(guān)算法的實(shí)現(xiàn)也是ACM中的常見(jiàn)題目,需要的朋友可以參考下2015-08-08
SpringBoot中使用@Async實(shí)現(xiàn)異步任務(wù)調(diào)用詳解
這篇文章主要介紹了SpringBoot中使用@Async實(shí)現(xiàn)異步任務(wù)調(diào)用詳解,一個(gè)可以無(wú)需等待被調(diào)用函數(shù)的返回值就讓操作繼續(xù)進(jìn)行的方法(來(lái)自百度百科),即程序在順序執(zhí)行時(shí),不等待異步調(diào)用的語(yǔ)句返回結(jié)果就執(zhí)行后面的程序,需要的朋友可以參考下2023-12-12

