您好,登錄后才能下訂單哦!
這篇“SpringMVC HttpMessageConverter報文信息轉換器怎么使用”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“SpringMVC HttpMessageConverter報文信息轉換器怎么使用”文章吧。
HttpMessageConverter 是報文信息轉換器,作用有 2 個:
將請求報文轉換為Java對象:請求報文是從瀏覽器發送到服務器,發送到服務器中就是 request 對象
將Java對象轉換為響應報文:響應報文是服務器響應給瀏覽器的,服務器中用的java,瀏覽器不能解析java,所以要轉換成響應報文給瀏覽器。
其中,HttpMessageConverter 提供了兩個注解:@RequestBody
,@ResponseBody
。還有兩個類型:RequestEntity
,ResponseEntity
。
最常用的還是用來將Java對象轉換為響應報文的兩個:@ResponseBody
和ResponseEntity
。
至于獲取請求參數,或者請求頭什么的,前面已經有過好幾種方法了,沒必要再使用這里的 @RequestBody
和 RequestEntity
。
@RequestBody
可以獲取請求體,需要在控制器方法設置一個形參,使用@RequestBody
進行標識,當前請求的請求體就會為當前注解所標識的形參賦值。
比如這有一個頁面表單,用來發送請求。
<form th:action="@{/testRequestBody}" method="post"> 用戶名:<input type="text" name="username"> 密碼:<input type="password" name="password"> <input type="submit"> </form>
對應的有個控制器處理這個請求:
@RequestMapping("/testRequestBody") public String testRequestBody(@RequestBody String requestBody){ System.out.println("requestBody:"+requestBody); return "success"; }
這里要補充一個 success.html 以供跳轉。
然后我們在表單中輸入 username=admin,password=123456,提交后,查看控制臺的輸出:
requestBody:username=admin&password=123456
username=admin&password=123456
這個就是請求體的內容了。
RequestEntity
是封裝請求報文的一種類型,包含了請求頭和請求體。
使用時,需要在控制器方法的形參中設置該類型的形參,當前請求的請求報文就會賦值給該形參。
接著,就可以通過getHeaders()
獲取請求頭信息,通過getBody()
獲取請求體信息。
復制一下上面的表單,請求地址換一下:
<form th:action="@{/testRequestEntity}" method="post"> 用戶名:<input type="text" name="username"><br> 密碼:<input type="password" name="password"><br> <input type="submit"> </form>
然后補充一個控制器方法:
@RequestMapping("/testRequestEntity") public String testRequestEntity(RequestEntity<String> requestEntity){ System.out.println("請求頭:"+requestEntity.getHeaders()); System.out.println("請求體:"+requestEntity.getBody()); return "success"; }
輸入表單提交測試一下:
在不使用@ResponseBody
這個注解的時候,使用servlet api 中 HttpServletResponse 也是可以響應給瀏覽器的。
比如:
@RequestMapping("/testResponse") public void testResponse(HttpServletResponse response) throws IOException { response.getWriter().print("hello, response"); }
前端寫一個超鏈接測試一下:
<a th:href="@{/testResponse}" rel="external nofollow" >使用HttpServletResponse響應瀏覽器</a>
點擊超鏈接。
使用@ResponseBody
則可以標識一個控制器方法,可以將該方法的返回值直接作為響應報文的響應體響應到瀏覽器。
@RequestMapping("/testResponseBody") @ResponseBody public String testResponseBody(){ return "success"; }
這里的控制器方法增加了@ResponseBody
:
如果沒有這個注解,返回的 "success"
,會匹配要跳轉的頁面。
加上之后, "success"
則不再代表視圖名稱,而是直接返回給瀏覽器的響應體。
繼續增加超鏈接測試一下:
<a th:href="@{/testResponseBody}" rel="external nofollow" >使用 @testResponseBody 響應瀏覽器</a>
注意,為了區分效果,success.html
里我修改下內容:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h2>這是 success.html 頁面</h2> </body> </html>
OK,現在點擊超鏈接,頁面顯示 success。
接著,我去掉控制器里的 @ResponseBody
,再重新部署點擊超鏈接試試。
跳轉到了 success.html 頁面。
所以,使用@ResponseBody
還是很方便的,我們需要返回給瀏覽器什么數據,直接在控制器方法里 return 即可。
上面示例響應的是個字符串,對于瀏覽器來說就直接顯示了。如果我要響應一個對象呢?
比如,新建一個 User 類,設置好構造方法,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, "男"); }
直接返回一個 User 對象。
為了測試,繼續在前端頁面增加一個超鏈接:
<a th:href="@{/testResponseUser}" rel="external nofollow" >響應瀏覽器User對象</a>
重新部署,點擊測試,報錯了。
這里還需要轉換的步驟,把 User 對象轉換成 json 格式的字符串。
在 pom.xml 中加入依賴 jackson
:
<!--對象轉化json 響應給瀏覽器--> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.12.1</version> </dependency>
另外,檢查一下 springMVC.xml 配置文件中的注解驅動是否開啟:
<!--開啟 mvc 的注解驅動--> <mvc:annotation-driven />
重新部署,點擊超鏈接。
響應正常。
使用ajax
發送請求,跟上面點擊超鏈接發送請,也只是發送請求方式不同而已,對于服務器來說,都是一樣處理。
ajax
的優點就是頁面不刷新的情況下,可以與服務器進行交互。
繼續在前端頁面增加內容,新增一個超鏈接,綁定一個點擊事件@click
:
<div id="app"> <a th:href="@{/testAjax}" rel="external nofollow" @click="testAjax">springMVC 處理ajax</a><br> </div>
這里需要用到靜態資源 vue.min.js
和 axios.min.js
,下載后放到webapp\static\js
下。
通過vue和axios處理點擊事件:
<!--引入--> <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) { // 請求處理成功后要執行的 alert(response.data) // 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"; }
重新部署之前,記得maven 重新打包一下。
另外,springMVC 配置文件中記得放開靜態資源的訪問:
<!--放開靜態資源的訪問--> <mvc:default-servlet-handler />
重新部署,點擊超鏈接。
這是以后會經常用的注解。
@RestController
注解是 springMVC 提供的一個復合注解。
標識在控制器的類上,就相當于為類添加了@Controller
注解,并且為其中的每個方法添加了@ResponseBody
注解。
ResponseEntity
用于控制器方法的返回值類型。
該控制器方法的返回值就是響應到瀏覽器的響應報文,后面的下載上傳文件的示例中會使用到。
以上就是關于“SpringMVC HttpMessageConverter報文信息轉換器怎么使用”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。