SpringMVC @RequestBody接收Json对象字符串--http://www.cnblogs.com/quanyongan/archive/2013/04/16/3024741.html

SpringMVC @RequestBody接收Json对象字符串

以前,一直以为在SpringMVC环境中,@RequestBody接收的是一个Json对象,一直在调试代码都没有成功,后来发现,其实 @RequestBody接收的是一个Json对象的字符串,而不是一个Json对象。然而在ajax请求往往传的都是Json对象,后来发现用 JSON.stringify(data)的方式就能将对象变成字符串。同时ajax请求的时候也要指定dataType: "json",contentType:"application/json" 这样就可以轻易的将一个对象或者List传到Java端,使用@RequestBody即可绑定对象或者List.

JavaScript 代码:

复制代码
<script type="text/javascript">  
    $(document).ready(function(){  
        var saveDataAry=[];  
        var data1={"userName":"test","address":"gz"};  
        var data2={"userName":"ququ","address":"gr"};  
        saveDataAry.push(data1);  
        saveDataAry.push(data2);         
        $.ajax({ 
            type:"POST", 
            url:"user/saveUser", 
            dataType:"json",      
            contentType:"application/json",               
            data:JSON.stringify(saveData), 
            success:function(data){ 
                                       
            } 
         }); 
    });  
</script> 
复制代码

Java代码

    @RequestMapping(value = "saveUser", method = {RequestMethod.POST }}) 
    @ResponseBody  
    public void saveUser(@RequestBody List<User> users) { 
         userService.batchSave(users); 
    } 

 

分类: SpringMVC
6
0
(请您对文章做出评价)
» 下一篇: Java中浏览器的文件下载时文件名乱码问题
posted @ 2013-04-16 21:07 QuantSeven 阅读( 62430) 评论( 16) 编辑 收藏

  
#1楼 2014-07-23 13:39 springmvc168  
springmvc代码下载:zuidaima.com/share/search.htm?key=springmvc
  
#2楼 2014-07-23 13:41 springmvc168  
springmvc代码下载:zuidaima.com/share/search.htm?key=springmvc
  
#3楼 2015-11-12 17:12 醉酒_HD  
请问你这个后台java代码中 userService.batchSave(users);
这个batchSave()方法 是怎么将list格式的数据存到数据库的。
  
#4楼 [ 楼主] 2015-11-12 22:51 QuantSeven  
@醉酒_HD
看你用什么持久化框架咯,我这里是用mybatis的,xml中使用<foreach标签
  
#5楼 2015-11-13 08:37 醉酒_HD  
@QuantSeven
我用的是spring mvc+mybatis框架,就是在myatis里面的mapping写sql语句啊。
  
#6楼 [ 楼主] 2015-11-13 08:55 QuantSeven  
@醉酒_HD
那就是这样的咯

1
2
3
4
5
6
7
<insert id= "batchSave" parameterType= "java.util.ArrayList" >
     INSERT INTO j_product_evaluation(PE_ID,PRODUCT_ID,EVALUATION_ITEM_ID,SCORE,STATUS,DESCRIPTION,USER_ID,CREATE_DATE)
     VALUES
     <foreach item= "item" index= "index" collection= "list" separator= "," >
         ( #{item.peId}, #{item.productId}, #{item.evaluationItemId} , #{item.score}, #{item.status}, #{item.description}, #{item.userId}, #{item.createDate})
     </foreach>
</insert>
  
#7楼 2015-11-13 09:28 醉酒_HD  
@QuantSeven
领教了,谢谢楼主,我再试试,用你的方法接收JOSN。
  
#8楼 2015-11-13 13:56 醉酒_HD  
解决了,我数据库设计的时候有个字段少了一个字母,真是醉了,搞了一天才弄清楚,再次谢谢楼主!
  
#9楼 2015-12-06 10:51 规格严格-功夫到家  
学习了~
  
#10楼 [ 楼主] 2015-12-06 10:52 QuantSeven  
@规格严格-功夫到家
加油
  
#11楼 2016-01-29 18:13 迷路的猫  
如何传递单个对象?一定要放在数组中才可以吗?
  
#12楼 [ 楼主] 2016-01-29 18:16 QuantSeven  
@迷路的猫
单个对象,Java端就直接一个对象接收就行了啊
  
#13楼 2016-01-29 19:45 迷路的猫  
搞定了,刚刚不知道什么地方出错了
  
#14楼 2016-02-26 10:11 util—u  
我加了 contentType:"application/json" 会报400错误,不加这句就是对的
  
#15楼 [ 楼主] 2016-02-26 10:14 QuantSeven  
SpringMVC端设置是否接收这个格式
  
#16楼 [ 楼主] 2016-02-26 10:14 QuantSeven  
@util—u
SpringMVC端设置是否接收这个格式
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值