HttpMessageConverter
HttpMessageConverter
,報文資訊轉換器,將請求報文轉換為Java物件,或將Java物件轉換為響應報文
HttpMessageConverter
提供了兩個註解和兩個型別:@RequestBody
,@ResponseBody
,RequestEntity
,ResponseEntity
@RequestBody
@RequestBody
可以獲取請求體,需要在控制器方法設定一個形參,使用@RequestBody
進行標識,當前請求的請求體就會為當前註解所標識的形參賦值
<form th:action="@{/testRequestBody}" method="post">
使用者名稱:<input type="text" name="username"><br>
密碼:<input type="password" name="password"><br>
<input type="submit">
</form>
@RequestMapping("/testRequestBody")
public String testRequestBody(@RequestBody String requestBody){
System.out.println("requestBody:"+requestBody);
return "success";
}
輸出結果:
requestBody:username=admin&password=123456
RequestEntity
RequestEntity
封裝請求報文的一種型別,需要在控制器方法的形參中設定該型別的形參,當前請求的請求報文就會賦值給該形參,可以通過getHeaders()
獲取請求頭資訊,通過getBody()
獲取請求體資訊
@RequestMapping("/testRequestEntity")
public String testRequestEntity(RequestEntity<String> requestEntity){
System.out.println("requestHeader:"+requestEntity.getHeaders());
System.out.println("requestBody:"+requestEntity.getBody());
return "success";
}
輸出結果:
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
用於標識一個控制器方法,可以將該方法的返回值直接作為響應報文的響應體響應到瀏覽器
@RequestMapping("/testResponseBody")
@ResponseBody
public String testResponseBody(){
return "success";
}
結果:
SpringMVC處理json
@ResponseBody
處理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 />
-
在處理器方法上使用
@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":"男"}
SpringMVC處理ajax
- 請求超連結:
<div id="app">
<a th:href="@{/testAjax}" @click="testAjax">testAjax</a><br>
</div>
- 通過vue和axios處理點選事件:
<script type="text/javascript" th:src="@{/static/js/vue.js}"></script>
<script type="text/javascript" th:src="@{/static/js/axios.min.js}"></script>
<script type="text/javascript">
var vue = new Vue({
el:"#app",
methods:{
testAjax:function (event) {
axios({
method:"post",
url:event.target.href,
params:{
username:"admin",
password:"123456"
}
}).then(function (response) {
alert(response.data);
});
event.preventDefault();
}
}
});
</script>
- 控制器方法:
@RequestMapping("/testAjax")
@ResponseBody
public String testAjax(String username, String password){
System.out.println("username:"+username+",password:"+password);
return "hello,ajax";
}
@RestController註解
@RestController
註解是springMVC提供的一個複合註解,標識在控制器的類上,就相當於為類新增了@Controller
註解,並且為其中的每個方法新增了@ResponseBody
註解
ResponseEntity
ResponseEntity
用於控制器方法的返回值型別,該控制器方法的返回值就是響應到瀏覽器的響應報文