Java SpringMVC的@RequestMapping注解使用及說(shuō)明
一、@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)求。
原因就是這個(gè)映射關(guān)系是唯一的,但在工程中這個(gè)是重復(fù)的。
二、@RequestMapping注解位置
@RequestMapping標(biāo)識(shí)在類上:設(shè)置映射請(qǐng)求的請(qǐng)求路徑的初始信息。
@RequestMapping標(biāo)識(shí)在方法上:設(shè)置映射請(qǐng)求的請(qǐng)求路徑的具體信息
@Controller //標(biāo)識(shí)在類上主要用于模塊間的控制 @RequestMapping("/hello") public class TestController01 { @RequestMapping("/success") public String success(){ return "success"; } }
index.html頁(yè)面
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h1>首頁(yè)</h1> <a th:href="@{/hello/success}">訪問(wèn)success頁(yè)面</a> </body> </html>
三、@RequestMapping注解的value屬性
1、@RequestMapping注解的value屬性是通過(guò)請(qǐng)求的請(qǐng)求地址匹配請(qǐng)求映射
2、@RequestMapping注解的value屬性是一個(gè)字符串類型的數(shù)組,表示該請(qǐng)求映射能夠匹配多個(gè)請(qǐng)求地址所對(duì)應(yīng)的請(qǐng)求。
3、@RequestMapping注解的value屬性必須設(shè)置,至少通過(guò)請(qǐng)求地址匹配請(qǐng)求映射
測(cè)試代碼:
@Controller public class TestController01 { @RequestMapping(value = {"hello","test"}) public String success(){ return "success"; } }
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h1>首頁(yè)</h1> <a th:href="@{/hello}">訪問(wèn)success頁(yè)面</a><br> <a th:href="@{/test}">訪問(wèn)success頁(yè)面</a> </body> </html>
四、@RequestMapping注解的method屬性
@RequestMapping注解的method屬性通過(guò)請(qǐng)求的請(qǐng)求方式(get或post)匹配請(qǐng)求映射。
@RequestMapping注解的method屬性是一個(gè)RequestMethod類型的數(shù)組,表示該請(qǐng)求映射能夠匹配多種請(qǐng)求方式的請(qǐng)求。
當(dāng)前請(qǐng)求的請(qǐng)求地址滿足請(qǐng)求映射的value屬性,但是請(qǐng)求方式不滿足method屬性,則瀏覽器報(bào)405;
在默認(rèn)請(qǐng)求方式下的post,get都能請(qǐng)求成功
controller層代碼不變。
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h1>首頁(yè)</h1> <form th:action="@{/hello}" method="post"> <input type="submit" value="在默認(rèn)方式下測(cè)試post"> </form> <form th:action="@{/test}" method="get"> <input type="submit" value="在默認(rèn)方式下測(cè)試get"> </form> </body> </html>
指定使用get請(qǐng)求:
@Controller public class TestController01 { @RequestMapping(value = {"hello","test"}, method = {RequestMethod.GET}) public String success(){ return "success"; } }
當(dāng)訪問(wèn)post請(qǐng)求時(shí)報(bào)錯(cuò)
根據(jù)需要可以設(shè)置多種請(qǐng)求方式
1、對(duì)于處理指定請(qǐng)求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解
處理get請(qǐng)求的映射使用GetMapping,處理post請(qǐng)求的映射使用PostMapping,處理put請(qǐng)求的映射使用PutMapping,處理delete請(qǐng)求的映射使用DeleteMapping。
@GetMapping("/test") public String getSuccess(){ return "success"; }
2、常用的請(qǐng)求方式有g(shù)et,post,put,delete
目前瀏覽器只支持get和post請(qǐng)求,若from表單在提交時(shí),使用method設(shè)置其他請(qǐng)求方式,則都按默認(rèn)請(qǐng)求方式get處理。
若要發(fā)送put和delete請(qǐng)求,則需要通過(guò)Spring提供的過(guò)濾器HiddenHttpMethodFilter。
五、@RequestMapping注解的params屬性
@RequestMapping注解的params屬性通過(guò)請(qǐng)求參數(shù)匹配請(qǐng)求映射
@RequestMapping注解的params屬性是一個(gè)字符串類型的數(shù)組,可以通過(guò)四種表達(dá)式設(shè)置請(qǐng)求參數(shù)和請(qǐng)求映射的匹配關(guān)系。
- "param":要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶param請(qǐng)求參數(shù)。
- "!param":要求請(qǐng)求映射所匹配的請(qǐng)求不能攜帶param請(qǐng)求參數(shù)。
- "param=value":要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶param請(qǐng)求參數(shù)且param=value。
- "param!=value":要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶param請(qǐng)求參數(shù)且param!=value。
@RequestMapping(value = "/test2", params = {"name=張三","password=123456"}) public String success(){ return "success"; }
<a th:href="@{/test2(name='張三',password=123456)}">攜帶params訪問(wèn)success頁(yè)面</a>
當(dāng)傳入?yún)?shù)匹配不上時(shí)就會(huì)報(bào)瀏覽器400錯(cuò)誤:
六、@RequestMapping注解的headers屬性
@RequestMapping注解的headers屬性通過(guò)請(qǐng)求的請(qǐng)求頭信息匹配請(qǐng)求映射。
@RequestMapping注解的headers屬性是一個(gè)字符串類型的數(shù)組,可以通過(guò)四種表達(dá)式設(shè)置請(qǐng)求頭信息和請(qǐng)求映射的匹配關(guān)系。
- “header”:要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶header請(qǐng)求頭信息。
- “!header”:要求請(qǐng)求映射所匹配的請(qǐng)求不能攜帶header請(qǐng)求頭信息。
- “header”:要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶header請(qǐng)求頭信息且header=value。
- “header”:要求請(qǐng)求映射所匹配的請(qǐng)求必須攜帶header請(qǐng)求頭信息且header!=value。
若當(dāng)前請(qǐng)求未滿足@RequestMapping注解的value和method屬性,但是不滿足headers屬性,頁(yè)面顯示404錯(cuò)誤。
@RequestMapping(value = "/test2", params = {"name=張三","password=123456"}, headers = {"Host=localhost:8081"}) public String success(){ return "success"; }
<a th:href="@{/test2(name='張三',password=123456)}">攜帶params訪問(wèn)success頁(yè)面</a>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud OpenFeign自定義結(jié)果解碼器方式
這篇文章主要介紹了SpringCloud OpenFeign自定義結(jié)果解碼器方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09springboot配置flyway(入門級(jí)別教程)
本文介紹了springboot配置flyway,主要介紹基于SpringBoot集成flyway來(lái)管理數(shù)據(jù)庫(kù)的變更,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09自己動(dòng)手編寫一個(gè)Mybatis插件之Mybatis脫敏插件
這篇文章主要介紹了自己動(dòng)手編寫一個(gè)Mybatis插件之Mybatis脫敏插件,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08詳解SpringBoot下文件上傳與下載的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot下文件上傳與下載的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05java中對(duì)象和JSON格式的轉(zhuǎn)換方法代碼
JSON格式可以輕松地以面向?qū)ο蟮姆绞睫D(zhuǎn)換為Java對(duì)象,下面這篇文章主要給大家介紹了關(guān)于java中對(duì)象和JSON格式的轉(zhuǎn)換方法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12javaweb 國(guó)際化:DateFormat,NumberFormat,MessageFormat,ResourceBu
本文主要介紹javaWEB國(guó)際化的知識(shí),這里整理了詳細(xì)的資料及實(shí)現(xiàn)代碼,有興趣的小伙伴可以參考下2016-09-09