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。
最常用的還是用來將Java對(duì)象轉(zhuǎn)換為響應(yīng)報(bào)文的兩個(gè):@ResponseBody和ResponseEntity。
至于獲取請(qǐng)求參數(shù),或者請(qǐng)求頭什么的,前面已經(jīng)有過好幾種方法了,沒必要再使用這里的 @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è)頁面表單,用來發(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ì)賦值給該形參。
接著,就可以通過getHeaders()獲取請(qǐng)求頭信息,通過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"); }
前端寫一個(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:
- 如果沒有這個(gè)注解,返回的 "success",會(huì)匹配要跳轉(zhuǎn)的頁面。
- 加上之后, "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 頁面</h1> </body> </html>
OK,現(xiàn)在點(diǎn)擊超鏈接,頁面顯示 success。
接著,我去掉控制器里的 @ResponseBody,再重新部署點(diǎn)擊超鏈接試試。
跳轉(zhuǎn)到了 success.html 頁面。
所以,使用@ResponseBody還是很方便的,我們需要返回給瀏覽器什么數(shù)據(jù),直接在控制器方法里 return 即可。
3. springMVC 處理 json
上面示例響應(yīng)的是個(gè)字符串,對(duì)于瀏覽器來說就直接顯示了。如果我要響應(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; ... ...
編寫控制器:
@RequestMapping("/testResponseUser") @ResponseBody public User testResponseUser() { return new User(1001, "大周", "123456", 11, "男"); }
直接返回一個(gè) User 對(duì)象。
為了測(cè)試,繼續(xù)在前端頁面增加一個(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)是否開啟:
<!--開啟 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ù)器來說,都是一樣處理。
ajax的優(yōu)點(diǎn)就是頁面不刷新的情況下,可以與服務(wù)器進(jìn)行交互。
繼續(xù)在前端頁面增加內(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下。
通過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 配置文件中記得放開靜態(tài)資源的訪問:
<!--放開靜態(tài)資源的訪問--> <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)文章
Spring Cloud入門系列服務(wù)提供者總結(jié)
這篇文章主要介紹了Spring Cloud入門系列之服務(wù)提供者總結(jié),服務(wù)提供者使用Eureka Client組件創(chuàng)建 ,創(chuàng)建完成以后修改某文件,具體操作方法及實(shí)例代碼跟隨小編一起看看吧2021-06-06超細(xì)致講解Spring框架 JdbcTemplate的使用
在之前的Javaweb學(xué)習(xí)中,學(xué)習(xí)了手動(dòng)封裝JdbcTemplate,其好處是通過(sql語句+參數(shù))模板化了編程。而真正的JdbcTemplate類,是Spring框架為我們寫好的。它是 Spring 框架中提供的一個(gè)對(duì)象,是對(duì)原始 Jdbc API 對(duì)象的簡(jiǎn)單封裝。2021-09-09Java畢業(yè)設(shè)計(jì)實(shí)戰(zhàn)之在線蛋糕銷售商城的實(shí)現(xiàn)
這是一個(gè)使用了java+JSP+Springboot+maven+mysql+ThymeLeaf+FTP開發(fā)的在線蛋糕銷售商城,是一個(gè)畢業(yè)設(shè)計(jì)的實(shí)戰(zhàn)練習(xí),具有線上蛋糕商城該有的所有功能,感興趣的朋友快來看看吧2022-01-01SpringBoot?Security從入門到實(shí)戰(zhàn)示例教程
Spring?Security是一個(gè)功能強(qiáng)大且高度可定制的身份驗(yàn)證和訪問控制框架,接下來通過本文給大家介紹SpringBoot?Security從入門到實(shí)戰(zhàn)示例教程,感興趣的朋友一起看看吧2022-05-05Java啟動(dòng)參數(shù)(-,?-X,?-XX參數(shù))的使用
本文主要介紹了Java啟動(dòng)參數(shù)(-,?-X,?-XX參數(shù))的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06Java實(shí)現(xiàn)warcraft?java版游戲的示例代碼
致敬經(jīng)典的warcraft,《warcraft?java版》是一款即時(shí)戰(zhàn)略題材單機(jī)游戲,采用魔獸原味風(fēng)格和機(jī)制。本文將用java語言實(shí)現(xiàn),采用了swing技術(shù)進(jìn)行了界面化處理,感興趣的可以了解一下2022-09-09使用java API實(shí)現(xiàn)zip遞歸壓縮和解壓文件夾
這篇文章主要介紹了使用java API實(shí)現(xiàn)zip遞歸壓縮文件夾及解壓,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08