Java @responsebody_springMvc注解之@ResponseBody和@RequestBody详解

简介

springmvc对json的前后台传输做了很好封装,避免了重复编码的过程,下面来看看常用的@ResponseBody和@RequestBody注解

添加依赖

springmvc对json的处理依赖jackson

org.codehaus.jackson

jackson-core-asl

1.9.11

org.codehaus.jackson

jackson-mapper-asl

1.9.11

xml配置

//不要忘了命名空间配置

@ResponseBody

如果传输的是单层json对象,我们后台可以直接用 @RequestParam接收

$.ajax({

type : "post",

dataType : "json",

url : "/testRequestBody",

data:{

name:"韦德",

age:35

},

success : function(result) {

}

});

@RequestMapping("/testRequestBody")

public String testRequestBody(@RequestParam Map map) {

System.out.println(map);// {name=韦德, age=35}

return "index";

}

如果传输的是多层嵌套json对象,这个时候会就会出现数据丢失问题

@ResponseBody很好的解决了这个问题,它会把前台传输过来的json转化为后台对应的对象

$.ajax({

type : "post",

dataType : "json",

url : "/testRequestBody",

contentType:"application/json",

data:JSON.stringify({

name:"韦德",

win:[2006,2012,2013],

age:35

}),

success : function(result) {

}

});

@RequestMapping("/testRequestBody")

public String testRequestBody(@RequestBody Map map) {

System.out.println(map);//{name=韦德, win=[2006, 2012, 2013], age=35}

return "index";

}

需要注意的是前台需要指定contentType为"application/json"

同时要把json对象转化为String,否则后台不能识别

@ResponseBody

ajax请求返回json格式,往常我们可以这样做

private void writeJson(HttpServletResponse response, Object object) {

String json = JSON.toJSONString(object);

response.setCharacterEncoding("UTF-8");

response.setContentType("application/json; charset=utf-8");

PrintWriter out = null;

try {

out = response.getWriter();

out.write(json);

} catch (IOException e) {

e.printStackTrace();

} finally {

if (out != null) {

out.close();

}

}

}

这个时候 @ResponseBody就派上用场了,只需要一个注解,全部搞定

$.ajax({

type : "post",

dataType : "json",

url : "/testResponseBody",

success : function(result) {

console.info(result);

}

});

@RequestMapping("/testResponseBody")

@ResponseBody

public Map testRequestBody() {

Map result = new HashMap();

result.put("name", "韦德");

result.put("age", 35);

return result;

}

前台console输出

{

"age": 35,

"name": "韦德"

}

总结

在网上看到很不错的流程图,作为总结吧

ec2e07b2015b0c2326daff328f0dafed.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值