Spring服務(wù)注解有哪些
@RequestMapping(value ="/xxx",method = RequestMethod.GET) @GetMapping,@PostMapping,@PutMapping,@DeleteMapping為@RequestMapping縮寫
1. @GetMapping
對應(yīng)注解
@RequestMapping(value = “/get/{id}”, method = RequestMethod.GET)
作用:對應(yīng)查詢,獲得數(shù)據(jù),表明是一個查詢請求
2. @PostMapping
對應(yīng)注解
@RequestMapping(value = “/add/user”,method = RequestMethod.POST)
作用:對應(yīng)添加,添加數(shù)據(jù),表明是一個添加請求
3. @PutMapping
對應(yīng)注解
@RequestMapping(value = “/modify/user”,method = RequestMethod.PUT)
作用:對應(yīng)更新,更新數(shù)據(jù),表明是一個更新請求
4. @DeleteMapping
對應(yīng)注解
@RequestMapping(value = “/del/{id}”,method = RequestMethod.DELETE)
作用:對應(yīng)刪除,刪除數(shù)據(jù),表明是一個刪除請求
5.@PathVariable
用于處理路徑參數(shù): /list/{id}
常用于Get,Delete
可以匹配正則表達(dá)式 例如:{id: [a-zA-Z0-9]+} 不符合正則會報404
@RequestMapping("/list/{id}") public xxx list(@PathVariable String id){ return xxx; } // 或者 @RequestMapping("/list/{id}") public xxx list(@PathVariable("id") String id){ return xxx; }
6. @RequestParam
用于處理請求頭內(nèi)的元素:Content-Type
常用于Get,Delete
可加可不加:不加則 /list或/list?id=xxx都能訪問成功服務(wù);
加上需要required默認(rèn)為true必須用/list?id=xxx,設(shè)置required為false則于不加一樣
@RequestMapping("/list") public xxx list(String id){ return xxx; } // 兩者效果一樣 @RequestMapping("/list") public xxx list(@RequestParam(value="id",required=false) String id){ return xxx; }
- value:請求參數(shù)名;
- required:是否必需,默認(rèn)為 true; true 標(biāo)識必須帶參數(shù)例如:/list?id=xxx;反之則為/list
- defaultValue:默認(rèn)值,設(shè)置該值,required 將自動設(shè)為 false,不傳則值為defaultValue設(shè)置的默認(rèn)值
7.@RequestBody
用于處理請求體中的內(nèi)容: application/json,application/xml
常用于:Post,Put
加上RequestBody后會自動轉(zhuǎn)換成map,list,實體類等
傳參的方式,對應(yīng)以上三種注解:
- 路徑參數(shù): /list/{id}
- 請求頭:/list?id=xxx
- 請求體: json或xml
@RequestParam和@PathVariable相同點和區(qū)別
相同點:
- 根據(jù)用戶輸入不同獲取不同服務(wù)
不同點:
PathVariable:
- 路徑傳值:/list/{name}/file/{id} => /list/user1/file/123; /list/user2/file/223
必須傳值
- 多用于:當(dāng)URL指向的是某一具體業(yè)務(wù)資源(或資源列表),例如博客,用戶時
RequestParam:
- 請求頭傳值/list?id=xxx
- 可以通過required選擇傳不傳
- 可以通過defaultValue設(shè)置默認(rèn)值
多用于:當(dāng)URL需要對資源或者資源列表進(jìn)行過濾,篩選時
8.RequestBody和RequestParam分別支持的類型
在 Spring MVC 中,`@RequestBody` 和 `@RequestParam` 注解都可以用于接收請求參數(shù),但是它們所支持的參數(shù)類型有所不同。
`@RequestBody` 注解不支持簡單類型參數(shù)的接收,它可以將請求體中的數(shù)據(jù)以快捷的方式綁定到 Java 對象或?qū)ο蠹?/strong>上。
需要注意的是,`@RequestBody` 默認(rèn)只能接收 Content-Type 為 application/json 的請求體,但是您可以通過配置更改為接收其他類型的請求體
例如 application/xml、application/x-www-form-urlencoded 等。
常見數(shù)據(jù)類型:
- JSONObject,List<String>, Map<String, String>,Java對象
- JSON 格式的請求體:將請求體轉(zhuǎn)為 Java 對象
- XML 格式的請求體:將請求體轉(zhuǎn)為 Java 對象
- application/x-www-form-urlencoded 格式的請求體:將請求體轉(zhuǎn)為一個 Map<String, String> 對象
`@RequestParam` 注解則用于接收 URL 查詢字符串中的參數(shù),或者表單中的參數(shù),它支持簡單類型參數(shù)的接收
例如 String、int、double 等基本類型,同時也支持自定義類型的轉(zhuǎn)換。
常見數(shù)據(jù)類型:
- String:接收一個字符串參數(shù)
- 基本類型:int、long、float、double、short、boolean 等
- 封裝類型:Integer、Long、Float、Double、Short、Boolean 等
- 日期類型:java.util.Date、java.time.Instant、java.time.LocalDate、java.time.LocalDateTime 等
- 文件類型:MultipartFile、Part 等
總之
當(dāng)您需要處理請求體中的數(shù)據(jù)時,使用 `@RequestBody` 注解;當(dāng)您需要處理 URL 中的查詢字符串或表單數(shù)據(jù)時,使用 `@RequestParam` 注解。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis?ofType和javaType的區(qū)別說明
這篇文章主要介紹了MyBatis?ofType和javaType的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02java實戰(zhàn)案例之用戶注冊并發(fā)送郵件激活/發(fā)送郵件驗證碼
現(xiàn)在很多的網(wǎng)站都提供有用戶注冊功能,當(dāng)我們注冊成功之后就會收到封注冊網(wǎng)站的郵件,郵件里包含了我們的注冊的用戶名和密碼及激活賬戶的超鏈接等信息,這篇文章主要給大家介紹了關(guān)于java實戰(zhàn)案例之用戶注冊并發(fā)送郵件激活/發(fā)送郵件驗證碼的相關(guān)資料,需要的朋友可以參考下2021-09-09SpringMVC中DispatcherServlet的HandlerMapping詳解
這篇文章主要介紹了SpringMVC中DispatcherServlet的HandlerMapping詳解,上回說的Handler,我們說是處理特定請求的,也就是說,不是所有的請求都能處理,那么問題來了,我們怎知道哪個請求是由哪個Handler處理的呢,需要的朋友可以參考下2023-10-10