一、使用說明
作用:該註解用於將 Controller 的方法返回的對象,通過 HttpMessageConverter
接口轉換爲指定格式的數據如: json,xml 等,通過 Response 響應給客戶端
需求:使用@ResponseBody
註解實現將 controller 方法返回對象轉換爲 json 響應給客戶端。
前置知識點:Springmvc 默認用 MappingJacksonHttpMessageConverter 對 json 數據進行轉換,需要加入 jackson 的包。
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.9.0</version>
</dependency>
同時還需要注意的情況:
DispatcherServlet會攔截到所有的資源,導致一個問題就是靜態資源(img、css、js)也會被攔截到,從而不能被使用。解決問題就是需要配置靜態資源不進行攔截,在springmvc.xml
配置文件添加如下配置
mvc:resources標籤配置不過濾
* location元素表示webapp目錄下的包下的所有文件
* mapping元素表示以/static開頭的所有請求路徑,如/static/a 或者/static/a/b
<!-- 設置靜態資源不過濾 -->
<mvc:resources location="/css/" mapping="/css/**"/> <!-- 樣式 -->
<mvc:resources location="/images/" mapping="/images/**"/> <!-- 圖片 -->
<mvc:resources location="/js/" mapping="/js/**"/> <!-- javascript -->
二、使用示例
(1)使用@RequestBody獲取請求體數據
<script>
// 頁面加載,綁定單擊事件
$(function () {
$("#btn").click(function () {
// 發送ajax請求
$.ajax({
// 編寫json格式,設置屬性和值
url: "user/testAjax",
contentType: "application/json;charset=UTF-8",
data: '{"username":"hehe","password":"123","age":30}',
dataType: "json",
type: "post",
success: function (data) {
// data服務器端響應的json的數據,進行解析
alert(data);
alert(data.username);
alert(data.password);
alert(data.age);
}
});
});
});
</script>
/* 獲取請求體的數據
* @param body
*/
@RequestMapping("/testJson")
public void testJson(@RequestBody String body) {
System.out.println(body);
}
(2)使用@RequestBody註解把json的字符串轉換成JavaBean的對象
(3)使用@ResponseBody註解把JavaBean對象轉換成json字符串,直接響應