使用spring mvc,Controller参数传参时,参数为一个对象的,在执行请求的时候,可以传递json数据,然后spring会自动解析json数据,并封装到这个对象中。
比如下面这段代码:
@RequestMapping(value = "json2Bean", consumes = "application/json", method = RequestMethod.POST) public CoreRole json2Bean(@RequestBody CoreRole role) { logger.info("【json2List测试】role = {}", role.toString()); return role; }
$(function(){ var data = {"code":"2","roleName":"大哥"} $.ajax({ url:'/coreRole/json2Bean.do', data:JSON.stringify(data), type:'POST', dataType:'json', contentType: "application/json;charset=UTF-8", success:function(data){ alert(JSON.stringify(data)); }, error:function(){ alert('error'); } }); })
查阅过一些资料,说spring mvc不支持将一个json数据直接封装成List对象集合。
可是现在项目中就有这样的需求,所以我抽时间做了测试,经测试,使用@RequestBody是可以做到这一步的。
PS:项目中使用fastjson 1.2.7版本,在spring mvc的配置文件中配置了一个convert。
好了,废话不多说,上代码
fastjson依赖:
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.7</version> </dependency>
spring mvc的配置文件:
<!-- 使用 fastjson替换默认jackson ,此配置请参考http://www.cnblogs.com/exmyth/p/4563673.html --> <mvc:annotation-driven> <mvc:message-converters register-defaults="true"> <!-- 配置Fastjson支持 --> <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> <value>text/json;charset=UTF-8</value> <value>application/json;charset=UTF-8</value> </list> </property> <!-- QuoteFieldNames-输出key时是否使用双引号,默认为true WriteMapNullValue-是否输出值为null的字段,默认为false WriteNullNumberAsZero-数值字段如果为null,输出为0,而非null WriteNullListAsEmpty-List字段如果为null,输出为[],而非null WriteNullStringAsEmpty-字符类型字段如果为null,输出为"",而非null WriteNullBooleanAsFalse-Boolean字段如果为null,输出为false,而非null --> <property name="features"> <list> <!-- <value>WriteMapNullValue</value> --> <value>QuoteFieldNames</value> </list> </property> </bean> </mvc:message-converters> </mvc:annotation-driven>
Controller代码:
@RequestMapping(value = "json2List", consumes = "application/json", method = RequestMethod.POST) public List<CoreRole> json2List(@RequestBody List<CoreRole> roles) { logger.info("【json2List测试】role = {}", roles.toString()); return roles; }
ajax代码:
$(function(){ var dataAry=[]; var data2 = {"code":"1","roleName":"大哥"} var data1 = {"code":"2","roleName":"二哥"} dataAry.push(data1); dataAry.push(data2); $.ajax({ url:'/coreRole/json2List.do', data:JSON.stringify(dataAry), type:'POST', dataType:'json', contentType: "application/json;charset=UTF-8", success:function(data){ alert(JSON.stringify(data)); }, error:function(){ alert('error'); } }); })
测试结果:
【json2List测试】role = [{"code":"2","roleName":"二哥"}, {"code":"1","roleName":"大哥"}]