SpringMVC?HttpMessageConverter報(bào)文信息轉(zhuǎn)換器
SpringMVC HttpMessageConverter報(bào)文信息轉(zhuǎn)換器
HttpMessageConverter 是報(bào)文信息轉(zhuǎn)換器,作用有 2 個(gè):
將請(qǐng)求報(bào)文轉(zhuǎn)換為Java對(duì)象:請(qǐng)求報(bào)文是從瀏覽器發(fā)送到服務(wù)器,發(fā)送到服務(wù)器中就是 request 對(duì)象
將Java對(duì)象轉(zhuǎn)換為響應(yīng)報(bào)文:響應(yīng)報(bào)文是服務(wù)器響應(yīng)給瀏覽器的,服務(wù)器中用的java,瀏覽器不能解析java,所以要轉(zhuǎn)換成響應(yīng)報(bào)文給瀏覽器。
其中,HttpMessageConverter 提供了兩個(gè)注解:@RequestBody,@ResponseBody。還有兩個(gè)類型:RequestEntity,ResponseEntity。
最常用的還是用來(lái)將Java對(duì)象轉(zhuǎn)換為響應(yīng)報(bào)文的兩個(gè):@ResponseBody和ResponseEntity。
至于獲取請(qǐng)求參數(shù),或者請(qǐng)求頭什么的,前面已經(jīng)有過(guò)好幾種方法了,沒(méi)必要再使用這里的 @RequestBody 和 RequestEntity。
一、@RequestBody
@RequestBody可以獲取請(qǐng)求體,需要在控制器方法設(shè)置一個(gè)形參,使用@RequestBody進(jìn)行標(biāo)識(shí),當(dāng)前請(qǐng)求的請(qǐng)求體就會(huì)為當(dāng)前注解所標(biāo)識(shí)的形參賦值。
比如這有一個(gè)頁(yè)面表單,用來(lái)發(fā)送請(qǐng)求。
<form th:action="@{/testRequestBody}" method="post">
用戶名:<input type="text" name="username">
密碼:<input type="password" name="password">
<input type="submit">
</form>對(duì)應(yīng)的有個(gè)控制器處理這個(gè)請(qǐng)求:
@RequestMapping("/testRequestBody")
public String testRequestBody(@RequestBody String requestBody){
System.out.println("requestBody:"+requestBody);
return "success";
}這里要補(bǔ)充一個(gè) success.html 以供跳轉(zhuǎn)。
然后我們?cè)诒韱沃休斎?username=admin,password=123456,提交后,查看控制臺(tái)的輸出:
requestBody:username=admin&password=123456
username=admin&password=123456這個(gè)就是請(qǐng)求體的內(nèi)容了。
二、RequestEntity
RequestEntity是封裝請(qǐng)求報(bào)文的一種類型,包含了請(qǐng)求頭和請(qǐng)求體。
使用時(shí),需要在控制器方法的形參中設(shè)置該類型的形參,當(dāng)前請(qǐng)求的請(qǐng)求報(bào)文就會(huì)賦值給該形參。
接著,就可以通過(guò)getHeaders()獲取請(qǐng)求頭信息,通過(guò)getBody()獲取請(qǐng)求體信息。
復(fù)制一下上面的表單,請(qǐng)求地址換一下:
<form th:action="@{/testRequestEntity}" method="post">
用戶名:<input type="text" name="username"><br>
密碼:<input type="password" name="password"><br>
<input type="submit">
</form>然后補(bǔ)充一個(gè)控制器方法:
@RequestMapping("/testRequestEntity")
public String testRequestEntity(RequestEntity<String> requestEntity){
System.out.println("請(qǐng)求頭:"+requestEntity.getHeaders());
System.out.println("請(qǐng)求體:"+requestEntity.getBody());
return "success";
}輸入表單提交測(cè)試一下:

三、@ResponseBody
1.不使用 @ResponseBody
在不使用@ResponseBody這個(gè)注解的時(shí)候,使用servlet api 中 HttpServletResponse 也是可以響應(yīng)給瀏覽器的。
比如:
@RequestMapping("/testResponse")
public void testResponse(HttpServletResponse response) throws IOException {
response.getWriter().print("hello, response");
}前端寫(xiě)一個(gè)超鏈接測(cè)試一下:
<a th:href="@{/testResponse}" rel="external nofollow" >使用HttpServletResponse響應(yīng)瀏覽器</a>
點(diǎn)擊超鏈接。

2.使用 @ResponseBody
使用@ResponseBody則可以標(biāo)識(shí)一個(gè)控制器方法,可以將該方法的返回值直接作為響應(yīng)報(bào)文的響應(yīng)體響應(yīng)到瀏覽器。
@RequestMapping("/testResponseBody")
@ResponseBody
public String testResponseBody(){
return "success";
}這里的控制器方法增加了@ResponseBody:
- 如果沒(méi)有這個(gè)注解,返回的 "success",會(huì)匹配要跳轉(zhuǎn)的頁(yè)面。
- 加上之后, "success"則不再代表視圖名稱,而是直接返回給瀏覽器的響應(yīng)體。
繼續(xù)增加超鏈接測(cè)試一下:
<a th:href="@{/testResponseBody}" rel="external nofollow" >使用 @testResponseBody 響應(yīng)瀏覽器</a>注意,為了區(qū)分效果,success.html 里我修改下內(nèi)容:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>這是 success.html 頁(yè)面</h1>
</body>
</html>OK,現(xiàn)在點(diǎn)擊超鏈接,頁(yè)面顯示 success。

接著,我去掉控制器里的 @ResponseBody,再重新部署點(diǎn)擊超鏈接試試。

跳轉(zhuǎn)到了 success.html 頁(yè)面。
所以,使用@ResponseBody還是很方便的,我們需要返回給瀏覽器什么數(shù)據(jù),直接在控制器方法里 return 即可。
3. springMVC 處理 json
上面示例響應(yīng)的是個(gè)字符串,對(duì)于瀏覽器來(lái)說(shuō)就直接顯示了。如果我要響應(yīng)一個(gè)對(duì)象呢?
比如,新建一個(gè) User 類,設(shè)置好構(gòu)造方法,set 和 get:
public class User {
private Integer id;
private String username;
private String password;
private Integer age;
private String sex;
... ...編寫(xiě)控制器:
@RequestMapping("/testResponseUser")
@ResponseBody
public User testResponseUser() {
return new User(1001, "大周", "123456", 11, "男");
}直接返回一個(gè) User 對(duì)象。
為了測(cè)試,繼續(xù)在前端頁(yè)面增加一個(gè)超鏈接:
<a th:href="@{/testResponseUser}" rel="external nofollow" >響應(yīng)瀏覽器User對(duì)象</a>重新部署,點(diǎn)擊測(cè)試,報(bào)錯(cuò)了。

這里還需要轉(zhuǎn)換的步驟,把 User 對(duì)象轉(zhuǎn)換成 json 格式的字符串。
在 pom.xml 中加入依賴 jackson:
<!--對(duì)象轉(zhuǎn)化json 響應(yīng)給瀏覽器-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.1</version>
</dependency>另外,檢查一下 springMVC.xml 配置文件中的注解驅(qū)動(dòng)是否開(kāi)啟:
<!--開(kāi)啟 mvc 的注解驅(qū)動(dòng)-->
<mvc:annotation-driven />重新部署,點(diǎn)擊超鏈接。

響應(yīng)正常。
4. springMVC 處理 ajax
使用ajax發(fā)送請(qǐng)求,跟上面點(diǎn)擊超鏈接發(fā)送請(qǐng),也只是發(fā)送請(qǐng)求方式不同而已,對(duì)于服務(wù)器來(lái)說(shuō),都是一樣處理。
ajax的優(yōu)點(diǎn)就是頁(yè)面不刷新的情況下,可以與服務(wù)器進(jìn)行交互。
繼續(xù)在前端頁(yè)面增加內(nèi)容,新增一個(gè)超鏈接,綁定一個(gè)點(diǎn)擊事件@click:
<div id="app">
<a th:href="@{/testAjax}" rel="external nofollow" @click="testAjax">springMVC 處理ajax</a><br>
</div>這里需要用到靜態(tài)資源 vue.min.js 和 axios.min.js,下載后放到webapp\static\js下。

通過(guò)vue和axios處理點(diǎn)擊事件:
<!--引入-->
<script type="text/javascript" th:src="@{/static/js/vue.min.js}"></script>
<script type="text/javascript" th:src="@{/static/js/axios.min.js}"></script>
<script>
new Vue({
el: "#app",
methods: {
testAjax: function (event) {
axios({
method: "post",
url: event.target.href,
params: {
username: "admin",
password: "123456"
}
}).then(function (response) {
// 請(qǐng)求處理成功后要執(zhí)行的
alert(response.data) // response.data 獲取到響應(yīng)的數(shù)據(jù)
});
event.preventDefault(); // 取消超鏈接的默認(rèn)行為
}
}
});
</script>增加對(duì)于的請(qǐng)求控制器:
@RequestMapping("/testAjax")
@ResponseBody
public String testAjax(String username, String password) {
System.out.println("username:" + username + ",password:" + password);
return "hello, Ajax";
}重新部署之前,記得maven 重新打包一下。
另外,springMVC 配置文件中記得放開(kāi)靜態(tài)資源的訪問(wèn):
<!--放開(kāi)靜態(tài)資源的訪問(wèn)-->
<mvc:default-servlet-handler />重新部署,點(diǎn)擊超鏈接。

四、@RestController 注解
這是以后會(huì)經(jīng)常用的注解。
@RestController注解是 springMVC 提供的一個(gè)復(fù)合注解。
標(biāo)識(shí)在控制器的類上,就相當(dāng)于為類添加了@Controller注解,并且為其中的每個(gè)方法添加了@ResponseBody注解。
五、ResponseEntity
ResponseEntity用于控制器方法的返回值類型。
該控制器方法的返回值就是響應(yīng)到瀏覽器的響應(yīng)報(bào)文,后面的下載上傳文件的示例中會(huì)使用到。
以上就是SpringMVC HttpMessageConverter報(bào)文信息轉(zhuǎn)換器的詳細(xì)內(nèi)容,更多關(guān)于SpringMVC HttpMessageConverter的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java連接SQL?Server數(shù)據(jù)庫(kù)的超詳細(xì)教程
最近在java連接SQL數(shù)據(jù)庫(kù)時(shí)會(huì)出現(xiàn)一些問(wèn)題,所以這篇文章主要給大家介紹了關(guān)于java連接SQL?Server數(shù)據(jù)庫(kù)的超詳細(xì)教程,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
Java內(nèi)部類_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
內(nèi)部類是指在一個(gè)外部類的內(nèi)部再定義一個(gè)類。下面通過(guò)本文給大家java內(nèi)部類的使用小結(jié),需要的朋友參考下吧2017-04-04
Android應(yīng)用開(kāi)發(fā)的一般文件組織結(jié)構(gòu)講解
這篇文章主要介紹了Android應(yīng)用開(kāi)發(fā)的一般文件組織結(jié)構(gòu)講解,同時(shí)附帶介紹了一個(gè)獲取Android的文件列表的方法,需要的朋友可以參考下2015-12-12
有關(guān)ServletConfig與ServletContext的訪問(wèn)
下面小編就為大家?guī)?lái)一篇有關(guān)ServletConfig與ServletContext的訪問(wèn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01
Spring boot定時(shí)任務(wù)的原理及動(dòng)態(tài)創(chuàng)建詳解
這篇文章主要給大家介紹了關(guān)于Spring boot定時(shí)任務(wù)的原理及動(dòng)態(tài)創(chuàng)建的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
Java利用MD5加鹽實(shí)現(xiàn)對(duì)密碼進(jìn)行加密處理
在開(kāi)發(fā)的時(shí)候,有一些敏感信息是不能直接通過(guò)明白直接保存到數(shù)據(jù)庫(kù)的。最經(jīng)典的就是密碼了。如果直接把密碼以明文的形式入庫(kù),不僅會(huì)泄露用戶的隱私,對(duì)系統(tǒng)也是極其的不厲。本文就來(lái)和大家介紹一下如何對(duì)密碼進(jìn)行加密處理,感興趣的可以了解一下2023-02-02
Spring中的ThreadPoolTaskExecutor線程池使用詳解
這篇文章主要介紹了Spring中的ThreadPoolTaskExecutor線程池使用詳解,ThreadPoolTaskExecutor 是 Spring框架提供的一個(gè)線程池實(shí)現(xiàn),用于管理和執(zhí)行多線程任務(wù),它是TaskExecutor接口的實(shí)現(xiàn),提供了在 Spring 應(yīng)用程序中創(chuàng)建和配置線程池的便捷方式,需要的朋友可以參考下2024-01-01

