HttpMessageConverter報文信息轉換器的深入講解
前言
HttpMessageConverter,報文信息轉換器,將請求報文轉換為Java對象,或將Java對象轉換為響應報文。
HttpMessageConverter提供瞭兩個註解和兩個類型:@RequestBody,@ResponseBody,RequestEntity,ResponseEntity。
HttpMessageConverter 介紹
org.springframework.http.converter.HttpMessageConverter 是一個策略接口,接口說明如下:
Strategy interface that specifies a converter that can convert from and to HTTP requests and responses. 簡單說就是 HTTP request (請求)和response (響應)的轉換器。該接口有隻有5個方法,簡單來說就是獲取支持的 MediaType(application/json之類),接收到請求時判斷是否能讀(canRead),能讀則讀(read);返回結果時判斷是否能寫(canWrite),能寫則寫(write)。這幾個方法先有個印象即可:
boolean canRead(Class<?> clazz, MediaType mediaType); boolean canWrite(Class<?> clazz, MediaType mediaType); List<MediaType> getSupportedMediaTypes(); T read(Class<? extends T> clazz, HttpInputMessage inputMessage) throws IOException, HttpMessageNotReadableException; void write(T t, MediaType contentType, HttpOutputMessage outputMessage) throws IOException, HttpMessageNotWritableException;
一、@RequestBody 請求體註解
@RequestBody可以獲取請求體,需要在控制器方法設置一個形參。
使用@RequestBody進行標識,當前請求的請求體就會為當前註解所標識的形參賦值。
1.1、表單提交模擬
<form th:action="@{/testRequestBody}" method="post"> 用戶名:<input type="text" name="username"><br> 密碼:<input type="password" name="password"><br> <input type="submit"> </form>
1.2、控制器方法示例
@RequestMapping("/testRequestBody") public String testRequestBody(@RequestBody String requestBody){ System.out.println("requestBody:"+requestBody); return "success"; }
輸出結果:
requestBody:username=admin&password=123456
二、RequestEntity 請求封裝對象
RequestEntity 封裝請求報文的一種類型,需要在控制器方法的形參中設置該類型的形參,當前請求的請求報文就會賦值給該形參。
- 通過getHeaders()獲取請求頭信息
- 通過getBody()獲取請求體信息
2.1、控制器方式示例
@RequestMapping("/testRequestEntity") public String testRequestEntity(RequestEntity<String> requestEntity){ System.out.println("requestHeader:"+requestEntity.getHeaders()); System.out.println("requestBody:"+requestEntity.getBody()); return "success"; }
2.2、輸出結果
requestHeader:[host:"localhost:8080", connection:"keep-alive", content-length:"27", cache-control:"max-age=0", sec-ch-ua:"" Not A;Brand";v="99", "Chromium";v="90", "Google Chrome";v="90"", sec-ch-ua-mobile:"?0", upgrade-insecure-requests:"1", origin:"http://localhost:8080", user-agent:"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36"] requestBody:username=admin&password=123
三、@ResponseBody 響應體註解
@ResponseBody用於標識一個控制器方法,可以將該方法的返回值直接作為響應報文的響應體響應到瀏覽器。
3.1、控制器方式示例
@RequestMapping("/testResponseBody") @ResponseBody public String testResponseBody(){ return "success"; }
結果:瀏覽器頁面顯示 success
3.2、SpringMVC 添加Json格式轉換器
首先:導入jackson的依賴
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.12.1</version> </dependency>
然後:在SpringMVC的核心配置文件中開啟mvc的註解驅動。
此時在HandlerAdaptor中會自動裝配一個消息轉換器:MappingJackson2HttpMessageConverter,可以將響應到瀏覽器的Java對象轉換為Json格式的字符串。
<mvc:annotation-driven />
3.3、控制器使用 Json 格式轉換器示例
在處理器方法上使用 @ResponseBody 註解進行標識。
將Java對象直接作為控制器方法的返回值返回,就會自動轉換為Json格式的字符串
@RequestMapping("/testResponseUser") @ResponseBody public User testResponseUser(){ return new User(1001,"admin","123456",23,"男"); }
瀏覽器的頁面中展示的結果:
{"id":1001,"username":"admin","password":"123456","age":23,"sex":"男"}
3.4、@RestController註解
@RestController註解是springMVC提供的一個復合註解,標識在控制器的類上。
相當於為類添加瞭@Controller註解,並且為其中的每個方法添加瞭@ResponseBody註解。
四、ResponseEntity 響應封裝對象
ResponseEntity 用於控制器方法的返回值類型,該控制器方法的返回值就是響應到瀏覽器的響應報文。
總結
到此這篇關於HttpMessageConverter報文信息轉換器的文章就介紹到這瞭,更多相關HttpMessageConverter報文信息轉換器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- SpringMVC HttpMessageConverter報文信息轉換器
- 基於@RequestBody和@ResponseBody及Stringify()的作用說明
- 基於params、@PathVariabl和@RequestParam的用法與區別說明
- SpringBoot多種場景傳參模式
- POST方法給@RequestBody傳參數失敗的解決及原因分析