SpringBoot中@PathVariable、@RequestParam和@RequestBody的區(qū)別和使用詳解
一、@PathVariable
1.1 restful風(fēng)格
1.1.1 概念
一種軟件架構(gòu)風(fēng)格、設(shè)計(jì)風(fēng)格,而不是標(biāo)準(zhǔn),只是提供了一組設(shè)計(jì)原則和約束條件。它主要用于客戶端和服務(wù)器交互類的軟件。基于這個(gè)風(fēng)格設(shè)計(jì)的軟件可以更簡(jiǎn)潔,更有層次,更易于實(shí)現(xiàn)緩存等機(jī)制。
1.1.2 特點(diǎn)
- REST:即 Representational State Transfer。(資源)表現(xiàn)層狀態(tài)轉(zhuǎn)化。是目前最流行的一種互聯(lián)網(wǎng)軟件架構(gòu)。它結(jié)構(gòu)清晰、符合標(biāo)準(zhǔn)、易于理解、擴(kuò)展方便,所以正得到越來越多網(wǎng)站的采用
- 資源(Resources):網(wǎng)絡(luò)上的一個(gè)實(shí)體,或者說是網(wǎng)絡(luò)上的一個(gè)具體信息。它可以是一段文本、一張圖片、一首歌曲、一種服務(wù),總之就是一個(gè)具體的存在。可以用一個(gè)URI(統(tǒng)一資源定位符)指向它,每種資源對(duì)應(yīng)一個(gè)特定的 URI 。要獲取這個(gè)資源,訪問它的URI就可以,因此 URI 即為每一個(gè)資源的獨(dú)一無二的識(shí)別符。
- 表現(xiàn)層(Representation):把資源具體呈現(xiàn)出來的形式,叫做它的表現(xiàn)層(Representation)。比如,文本可以用 txt 格式表現(xiàn),也可以用 HTML 格式、XML 格式、JSON 格式表現(xiàn),甚至可以采用二進(jìn)制格式。
- 狀態(tài)轉(zhuǎn)化(State Transfer):每發(fā)出一個(gè)請(qǐng)求,就代表了客戶端和服務(wù)器的一次交互過程。HTTP協(xié)議,是一個(gè)無狀態(tài)協(xié)議,即所有的狀態(tài)都保存在服務(wù)器端。因此,如果客戶端想要操作服務(wù)器,必須通過某種手段,讓服務(wù)器端發(fā)生**“狀態(tài)轉(zhuǎn)化”**(State Transfer)。而這種轉(zhuǎn)化是建立在表現(xiàn)層之上的,所以就是 “表現(xiàn)層狀態(tài)轉(zhuǎn)化”。具體說,就是 HTTP 協(xié)議里面,四個(gè)表示操作方式的動(dòng)詞:GET、POST、PUT、DELETE。它們分別對(duì)應(yīng)四種基本操作:GET 用來獲取資源,POST 用來新建資源,PUT 用來更新資源,DELETE 用來刪除資源。
1.1.3 restful風(fēng)格和傳統(tǒng)操作方式的對(duì)比
功能 | 傳統(tǒng)方式 | restful風(fēng)格 |
查詢 | http://127.0.0.1/item/selectUser?id=1 | GET http://127.0.0.1/item/selectUser/1 |
新增 | http://127.0.0.1/item/addUser | POST http://127.0.0.1/item/addUser |
更新 | http://127.0.0.1/item/updateUser | PUT http://127.0.0.1/item/updateUser |
刪除 | http://127.0.0.1/item/deleteUser?id=1 | DELETE http://127.0.0.1/item/deleteUser/1 |
1.2 @PathVariable的介紹
@PathVariable 映射 URL 綁定的占位符
- 帶占位符的 URL 是 Spring3.0 新增的功能,該功能在SpringMVC 向 REST 目標(biāo)挺進(jìn)發(fā)展過程中具有里程碑的意義
- 通過 @PathVariable 可以將 URL 中占位符參數(shù)綁定到控制器(controller)處理方法的形參中:URL 中的 {xxx} 占位符可以通過@PathVariable(“xxx“) 綁定到操作方法的形參中。
- 主要是根據(jù)請(qǐng)求方法進(jìn)行類的區(qū)別
1.3 @PathVariable所具有的參數(shù)
- String value:可指定占位符 { } 中的參數(shù)名,若只指定value這一個(gè)屬性可省略屬性名不寫,若占位符中的參數(shù)名和處理方法中的參數(shù)名相同可省略此屬性。
- String name:等價(jià)與value,和value無本質(zhì)上的差異,兩個(gè)屬性指定其一即可。
- boolean required:是否必需,默認(rèn)為 true,即 請(qǐng)求中必須包含該參數(shù),如果沒有包含,將會(huì)拋出異常(可選配置)
1.4 @PathVariable的使用
步驟:
- 通過@RequestMapping注解中的 { } 占位符來標(biāo)識(shí)URL中的變量部分
- 在控制器中的處理方法的形參中使用@PathVariable注解去獲取@RequestMapping中 { } 中傳進(jìn)來的值,并綁定到處理方法定一的形參上。
//請(qǐng)求路徑:http://127.0.0.1/user/tom @RequestMapping(value="/user/{name}") public String username(@PathVariable(value="name") String username) { return username; }
二、@RequestParam
2.1 @RequestParam定義
@RequestParam (org.springframework.web.bind.annotation.RequestParam)用于將指定的請(qǐng)求參數(shù)賦值給方法中的形參。
2.2 @RequestParam的參數(shù)
- String value:請(qǐng)求中傳入?yún)?shù)的名稱,如果不設(shè)置value值,則會(huì)默認(rèn)為該變量名。
- String name:等價(jià)與value,和value無本質(zhì)上的差異,兩個(gè)屬性指定其一即可。
- boolean required:是否必需,默認(rèn)為 true,即 請(qǐng)求中必須包含該參數(shù),如果沒有包含,將會(huì)拋出異常(可選配置)
- String defaultValue:參數(shù)的默認(rèn)值,如果請(qǐng)求中沒有同名的參數(shù)時(shí),該變量默認(rèn)為此值。
2.3 注意事項(xiàng)
- 如果參數(shù)前寫了@RequestParam(xxx),那么前端必須有對(duì)應(yīng)的xxx名字才行(不管其是否有值,當(dāng)然可以通 過設(shè)置該注解的required屬性來調(diào)節(jié)是否必須傳),如果沒有xxx名的話,那么請(qǐng)求會(huì)出錯(cuò),報(bào)400。
- 如果參數(shù)前不寫@RequestParam(xxx)的話,那么就前端可以有可以沒有對(duì)應(yīng)的xxx名字才行,如果有xxx名的話,那么就會(huì)自動(dòng)匹配;沒有的話,請(qǐng)求也能正確發(fā)送。
2.4 @RequestParam使用
在SpringMVC框架中,可以通過定義@RequestMapping來處理URL請(qǐng)求。和@PathVariable一樣,需要在處理URL的控制方法中獲取URL中的參數(shù),也就是?key1=value1&key2=value2這樣的參數(shù)列表。通過注解@RequestParam可以輕松地將URL中的參數(shù)綁定到處理函數(shù)方法的變量中。
//請(qǐng)求路徑:http://127.0.0.1/user/?name=tom @RequestMapping(value="/user") public String getUserBlog(@RequestParam(value="name") String username) { return name; }
三、@RequestBody
3.1 @RequestBody簡(jiǎn)介
@RequestBody主要用來接收前端傳遞給后端的json字符串中的數(shù)據(jù)的(請(qǐng)求體中的數(shù)據(jù)的);GET方式無請(qǐng)求體,所以使用@RequestBody接收數(shù)據(jù)時(shí),前端不能使用GET方式提交數(shù)據(jù),而是用POST等方式進(jìn)行提交。
3.2 注意事項(xiàng)
如果后端參數(shù)是一個(gè)對(duì)象,且該參數(shù)前是以@RequestBody修飾的,那么前端傳遞json參數(shù)時(shí),必須滿足以下要求:
- 后端@RequestBody注解對(duì)應(yīng)的類在將HTTP的輸入流(含請(qǐng)求體)裝配到目標(biāo)類(即:@RequestBody后面的類)時(shí),會(huì)根據(jù)json字符串中的key來匹配對(duì)應(yīng)實(shí)體類的屬性,如果匹配一致且json中的該key對(duì)應(yīng)的值符合(或可轉(zhuǎn)換為), 實(shí)體類的對(duì)應(yīng)屬性的類型要求時(shí),會(huì)調(diào)用實(shí)體類的setter方法將值賦給該屬性。
- json字符串中,如果value為""的話,后端對(duì)應(yīng)屬性如果是String類型的,那么接受到的就是"",如果是后端屬性的類型是Integer、Double等類型,那么接收到的就是null。
- json字符串中,如果value為null的話,后端對(duì)應(yīng)收到的就是null。
- 如果某個(gè)參數(shù)沒有value的話,在傳json字符串給后端時(shí),要么干脆就不把該字段寫到j(luò)son字符串中;要么寫value時(shí), 必須有值,null 或""都行。
3.3 @RequestBody使用
3.3.1 編寫實(shí)體類User
@Data @AllArgsConstructor @NoArgsConstructor public class User { private String name; private int age; private String gender; }
3.3.2 編寫controller
@RestController @RequestMapping("/user") public class UserController { @PostMapping("/addUser") public void addUser(@RequestBody User user){ System.out.println(user); } }
3.3.3 使用postman進(jìn)行接口測(cè)試
3.3.4 后臺(tái)數(shù)據(jù)輸出
3.4 @RequestParam和@RequestBody
當(dāng)同時(shí)使用 @RequestParam 和 @RequestBody 時(shí),@RequestParam指定的參數(shù)可以是普通元素、 數(shù)組、集合、對(duì)象等等(即:當(dāng),@RequestBody 與@RequestParam 可以同時(shí)使用時(shí),原SpringMVC接收 參數(shù)的機(jī)制不變,只不過RequestBody 接收的是請(qǐng)求體里面的數(shù)據(jù);而@RequestParam接收的是key-value 里面的參數(shù),所以它會(huì)被切面進(jìn)行處理從而可以用普通元素、數(shù)組、集合、對(duì)象等接收)。
即:如果參數(shù)時(shí)放在請(qǐng)求體中,傳入后臺(tái)的話,那么后臺(tái)要用@RequestBody才能接收到;如果不是放在 請(qǐng)求體中的話,那么后臺(tái)接收前臺(tái)傳過來的參數(shù)時(shí),要用@RequestParam來接收,或則形參前什么也不寫也能接收。
四、@RequestParam和@PathVariable的區(qū)別
@RequestParam和@PathVariable都能夠完成類似的功能——因?yàn)楸举|(zhì)上,它們都是用戶的輸入,只不過輸入的部分不同,一個(gè)在URL路徑部分,另一個(gè)在參數(shù)部分。要訪問一篇博客文章,這兩種URL設(shè)計(jì)都是可以的:
- 通過@PathVariable,例如/blogs/1
- 通過@RequestParam,例如blogs?blogId=1
那么究竟應(yīng)該選擇哪一種呢?建議:
1、當(dāng)URL指向的是某一具體業(yè)務(wù)資源(或資源列表),例如博客,用戶時(shí),使用@PathVariable
2、當(dāng)URL需要對(duì)資源或者資源列表進(jìn)行過濾,篩選時(shí),用@RequestParam
例如我們會(huì)這樣設(shè)計(jì)URL:
- /blogs/{blogId}
- /blogs?state=publish而不是/blogs/state/publish來表示處于發(fā)布狀態(tài)的博客文章
到此這篇關(guān)于SpringBoot中@PathVariable、@RequestParam和@RequestBody的區(qū)別和使用詳解的文章就介紹到這了,更多相關(guān)@PathVariable、@RequestParam和@RequestBody的區(qū)別內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)漢字轉(zhuǎn)unicode與漢字轉(zhuǎn)16進(jìn)制實(shí)例
這篇文章主要介紹了java實(shí)現(xiàn)漢字轉(zhuǎn)unicode與漢字轉(zhuǎn)16進(jìn)制的實(shí)現(xiàn)方法,是Java操作漢字編碼轉(zhuǎn)換的一個(gè)典型應(yīng)用,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10學(xué)會(huì)在Java中使用Optional功能
這篇文章主要介紹了學(xué)會(huì)在Java中使用Optional功能,在本文中,我們將了解如何、何時(shí)以及在哪里最好地應(yīng)用Optional,具體相關(guān)內(nèi)容需要的朋友可以參考下面文章內(nèi)容2022-09-09Java在長(zhǎng)字符串中查找短字符串的實(shí)現(xiàn)多種方法
這篇文章主要介紹了Java在長(zhǎng)字符串中查找短字符串的實(shí)現(xiàn)多種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12詳解springboot啟動(dòng)時(shí)是如何加載配置文件application.yml文件
這篇文章主要介紹了詳解springboot啟動(dòng)時(shí)是如何加載配置文件application.yml文件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06使用TraceId在Spring Cloud中實(shí)現(xiàn)線上問題快速定位
在微服務(wù)架構(gòu)中,服務(wù)間的互相調(diào)用使得問題定位變得復(fù)雜,在此背景下,TraceId為我們提供了一個(gè)在復(fù)雜環(huán)境中追蹤請(qǐng)求路徑和定位問題的工具,本文不僅介紹TraceId的基本概念,還將結(jié)合真實(shí)場(chǎng)景,為您展示如何在Spring Cloud中應(yīng)用它2023-09-09設(shè)置JavaScript自動(dòng)提示-Eclipse/MyEclipse
自動(dòng)提示需要2個(gè)組件,分別是:ext-4.0.2a.jsb2||spket-1.6.16.jar,需要的朋友可以參考下2016-05-05