@RequestAttribute和@RequestParam注解的區(qū)別及說明
@RequestAttribute和@RequestParam注解區(qū)別
在寫http接口的時候,發(fā)現(xiàn)接口參數(shù)有兩種注解,一種是@RequestAttribute,一種是@Requestparam,自己剛開始沒明白區(qū)別,用postman調(diào)試的時候一直報錯,后來才發(fā)現(xiàn)這個問題。
@RequestAttribute注解的參數(shù)在項目里是自己解析出來的,并不是前端傳遞的。具體一點(diǎn),在項目里的攔截器里會對Token信息進(jìn)行解析,解析出來的參數(shù)重新放在請求里(用httpServletRequest.setAttribute(name, value)),后邊接口接收參數(shù)時就用這個注解。
@RequestParam注解則表示這個參數(shù)是通過前端傳遞過來的,如果請求里沒有這個參數(shù),則會報錯400 Bad Request。這個注解用來解析請求路徑里的參數(shù)(get請求)或者post請求中form表單格式的請求參數(shù);
@RequestBody注解用來接收POST請求BODY里的參數(shù),格式為JSON格式。
RequestAttribute、RequestBody、RequestHeader、RequestMethod、RequestParam和RequestPart
在Spring框架中,特別是在Spring MVC中,RequestAttribute
、RequestBody
、RequestHeader
、RequestMethod
、RequestParam
和RequestPart
等注解用于處理HTTP請求的不同部分,并幫助開發(fā)者從請求中提取信息或綁定請求體到Java對象。
下面是對這些注解的詳細(xì)解釋:
RequestAttribute
@RequestAttribute
注解用于訪問存儲在請求屬性中的值。
請求屬性是在請求處理過程中存儲在HttpServletRequest
對象中的鍵值對。
示例:
@GetMapping("/example") public String example(@RequestAttribute("attributeName") String value) { // 使用從請求屬性中獲取的值 return "ViewName"; }
RequestBody
@RequestBody
注解用于將請求體中的數(shù)據(jù)綁定到一個Java對象上。
這通常用于處理POST和PUT請求,其中請求體包含JSON或其他格式的數(shù)據(jù)。
示例:
@PostMapping("/create") public ResponseEntity<String> create(@RequestBody MyObject myObject) { // 使用從請求體中綁定的對象 return ResponseEntity.ok().body("Object created"); }
RequestHeader
@RequestHeader
注解用于訪問HTTP請求頭中的值。
它允許你獲取特定請求頭的值,并將其綁定到方法的參數(shù)上。
示例:
@GetMapping("/header") public String header(@RequestHeader("User-Agent") String userAgent) { // 使用從請求頭中獲取的用戶代理字符串 return "ViewName"; }
RequestMethod
RequestMethod
不是一個注解,而是一個枚舉類型,用于表示HTTP請求的方法類型,如GET、POST、PUT、DELETE等。
它通常與@RequestMapping
注解一起使用,以指定方法應(yīng)該響應(yīng)哪種類型的請求。
示例:
@RequestMapping(value = "/update", method = RequestMethod.PUT) public ResponseEntity<String> update(...) { // 處理PUT請求 }
RequestParam
@RequestParam
注解用于從請求參數(shù)中綁定值到方法的參數(shù)。
它通常用于處理GET請求中的查詢參數(shù)。
示例:
@GetMapping("/search") public String search(@RequestParam String query) { // 使用從查詢參數(shù)中獲取的查詢字符串 return "ViewName"; }
RequestPart
@RequestPart
注解通常用于處理multipart/form-data
類型的請求,這種請求通常用于文件上傳。
它允許你訪問請求中的某個部分,可以是文件或表單字段。
示例(文件上傳):
@PostMapping("/upload") public ResponseEntity<String> upload(@RequestPart("file") MultipartFile file) { // 處理文件上傳 return ResponseEntity.ok().body("File uploaded successfully"); }
這些注解使得開發(fā)者能夠方便地處理HTTP請求的各個方面,從請求頭到請求體,再到查詢參數(shù)和請求屬性。它們減少了手動解析和處理請求數(shù)據(jù)的需要,使得代碼更加簡潔和易讀。同時,通過使用這些注解,Spring MVC能夠自動進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換和校驗,進(jìn)一步簡化了Web開發(fā)的流程。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
- @RequestParam注解加與不加有什么區(qū)別
- 基于params、@PathVariabl和@RequestParam的用法與區(qū)別說明
- 基于@RequestParam name和value屬性的區(qū)別
- @RequestBody,@RequestParam和@Param的區(qū)別說明
- 方法參數(shù)屬性params,@PathVariable和@RequestParam用法及區(qū)別
- @PathVariable、@RequestParam和@RequestBody的區(qū)別
- @RequestParam?和@RequestBody注解的區(qū)別解析
- Springboot中@RequestParam和@PathVariable的用法與區(qū)別詳解
- Spring中@PathVariable和@RequestParam注解的用法區(qū)別
- SpringBoot中@PathVariable、@RequestParam和@RequestBody的區(qū)別和使用詳解
- springMVC中@RequestParam和@RequestPart的區(qū)別
相關(guān)文章
java 注解annotation的使用以及反射如何獲取注解
這篇文章主要介紹了java 注解annotation的使用以及反射如何獲取注解的相關(guān)資料,需要的朋友可以參考下2017-01-01Java線程間協(xié)作wait、notify和notifyAll詳解
這篇文章主要介紹了Java線程間協(xié)作wait、notify和notifyAll詳解,在 Java 中可以用 wait、notify 和 notifyAll 來實現(xiàn)線程間的通信,盡管關(guān)于wait和notify的概念很基礎(chǔ),它們也都是Object類的函數(shù),但用它們來寫代碼卻并不簡單,,需要的朋友可以參考下2023-10-10常用Maven庫,鏡像庫及maven/gradle配置(小結(jié))
這篇文章主要介紹了常用Maven庫,鏡像庫及maven/gradle配置(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12SpringBoot+SpringSecurity處理Ajax登錄請求問題(推薦)
這篇文章主要介紹了SpringBoot+SpringSecurity處理Ajax登錄請求問題,本文給大家介紹的非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-12-12java多線程中的生產(chǎn)者和消費(fèi)者隊列詳解
這篇文章主要介紹了java多線程中的生產(chǎn)者和消費(fèi)者隊列詳解,隊列,是一種數(shù)據(jù)結(jié)構(gòu),除了優(yōu)先級隊列和LIFO隊列外,隊列都是以FIFO(先進(jìn)先出)的方式對各個元素進(jìn)行排序的,需要的朋友可以參考下2024-01-01Intellij IDEA基于Springboot的遠(yuǎn)程調(diào)試(圖文)
這篇文章主要介紹了Intellij IDEA基于Springboot的遠(yuǎn)程調(diào)試(圖文),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10