一、使用说明
作用:该注解用于将 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字符串,直接响应