使用ResponseEntity作為的返回值的應(yīng)用
ResponseEntity作為的返回值
通常如果后端想響應(yīng)json數(shù)據(jù),我們需要在方法體上添加@Response注解,標(biāo)注這個注解的方法的返回值會被spingmvc轉(zhuǎn)為json形式并寫入到響應(yīng)體中。
但ResponseEntity則不會被springmvc轉(zhuǎn)換,可以使用這個類定義響應(yīng)頭,狀態(tài)碼,響應(yīng)體等。
@Controller
public class ResponseBodyTest {
@ResponseBody
@GetMapping("b1")
public R b1(){
//將方法的返回值轉(zhuǎn)為json寫入到響應(yīng)體中
return R.ok().put("msg","success");
}
@ResponseBody
@GetMapping("b2")
public ResponseEntity<String> b2(){
HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.TEXT_PLAIN);
String str = "hello,world";
ResponseEntity responseEntity = new ResponseEntity<String>(str,httpHeaders,HttpStatus.OK);
return responseEntity;
}
}
我們 /b2 請求設(shè)置了@ResponseBody注解,但由于返回的是ResponseEntity對象,而且我們又重新設(shè)置了響應(yīng)類型為 text/plain,我們訪問b2請求查看結(jié)果:

心得
ResponseEntity的優(yōu)先級高于@ResponseBody。
在不是ResponseEntity的情況下才去檢查有沒有@ResponseBody注解。如果響應(yīng)類型是ResponseEntity可以不寫@ResponseBody注解,寫了也沒有關(guān)系。
簡單的說@ResponseBody可以直接返回Json結(jié)果, @ResponseEntity不僅可以返回json結(jié)果,還可以定義返回的HttpHeaders和HttpStatus。
統(tǒng)一結(jié)果返回 ResponseEntity
在正規(guī)的嚴(yán)格的企業(yè)的前后端系統(tǒng)開發(fā)中,返回嚴(yán)謹(jǐn)?shù)臓顟B(tài)碼很有必要
平常大家為了統(tǒng)一格式返回,或許會自己封裝一個ResultUtils,然后自定義ResultCode枚舉類來返回,這樣有些麻煩;
我們可以使用SpringMVC為我們封裝的ResponseEntity對象來自定義狀態(tài)碼
源碼:
public class ResponseEntity<T> extends HttpEntity<T> {
private final Object status;
public ResponseEntity(HttpStatus status) {
this((Object)null, (MultiValueMap)null, (HttpStatus)status);
}
public ResponseEntity(@Nullable T body, HttpStatus status) {
this(body, (MultiValueMap)null, (HttpStatus)status);
}
public ResponseEntity(MultiValueMap<String, String> headers, HttpStatus status) {
this((Object)null, headers, (HttpStatus)status);
}
public ResponseEntity(@Nullable T body, @Nullable MultiValueMap<String, String> headers, HttpStatus status) {
super(body, headers);
Assert.notNull(status, "HttpStatus must not be null");
this.status = status;
}
private ResponseEntity(@Nullable T body, @Nullable MultiValueMap<String, String> headers, Object status) {
super(body, headers);
Assert.notNull(status, "HttpStatus must not be null");
this.status = status;
}@param body: the entity body
- ResponseEntity需要一個泛型T
- 代表我們需要傳入的數(shù)據(jù)對象
@param headers : the entity headers
- 我們可以new MultiValueMap<String, String> headers
- 設(shè)置響應(yīng)頭信息
@param status: the status code
- 我們可以使用HttpStatus
- 也可以自己定義狀態(tài)碼(Object)
HttpStatus status是一個包含了各種響應(yīng)狀態(tài)碼的枚舉類
// 201:創(chuàng)建成功 Created // 203 :沒有認(rèn)證 NON_AUTHORITATIVE_INFORMATION // 204: 成功沒有返回值 No-content 一般是delete,update時使用 .....
例子:
@GetMapping("/categories")
public ResponseEntity<List<Category>> getCategoryList(String token){
return new ResponseEntity<>(categoryService.queryAll(), HttpStatus.OK);
}
@PostMapping("/categories")
public ResponseEntity<Category> AddCategory(String token, @RequestBody Category category){
return new ResponseEntity<>(categoryService.insert(category),HttpStatus.CREATED);
}總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java觀察者模式之實(shí)現(xiàn)對象間的一對多依賴
這篇文章主要介紹了Java觀察者模式之實(shí)現(xiàn)對象間的一對多依賴的方法,Java觀察者模式是一種行為型設(shè)計模式,用于實(shí)現(xiàn)對象之間的消息傳遞和通信,文中有詳細(xì)的實(shí)現(xiàn)步驟和代碼示例,,需要的朋友可以參考下2023-05-05
Java并發(fā)編程之Semaphore(信號量)詳解及實(shí)例
這篇文章主要介紹了Java并發(fā)編程之Semaphore(信號量)詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-06-06
SpringBoot啟動并初始化執(zhí)行sql腳本問題
這篇文章主要介紹了SpringBoot啟動并初始化執(zhí)行sql腳本問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
Spring框架中Bean的三種配置和實(shí)例化方法總結(jié)
在Spring框架中,Bean的配置和實(shí)例化是很重要的基礎(chǔ)內(nèi)容,掌握各種配置方式,才能靈活管理Bean對象,本文將全面介紹Bean的別名配置、作用范圍配置,以及構(gòu)造器實(shí)例化、工廠實(shí)例化等方式2023-10-10
Spring?Cloud負(fù)載均衡組件Ribbon原理解析
本文主要講述了微服務(wù)體系下的?Spring?Cloud?Netflix?套件中?Ribbon?的使用,并結(jié)合部分源碼講述了?Ribbon?的底層原理,重點(diǎn)講述了?Ribbon?中是如何獲取服務(wù)以及如何判定一個服務(wù)是否可用,最后也介紹了?Ribbon?中默認(rèn)提供的?7?種負(fù)載均衡策略,感興趣的朋友一起看看吧2022-04-04

