详解使用@RequestBody取POST方式的json字符串

关于@RequestBody 映射实体类的方法,网上大量讨论,不再细说。

但前端提交复杂结构,或动态性比较大的数据结构时,就可能不能映射固定类。用map方式貌似也不太灵(没有仔细研究,过程中,前端json结构比较复杂时,失败了)。

前端写法:

 var json_data={
       "name" : "demographics",
       "params" : [1 , 2, 3],
       "items" : [ {"name" : "中文", "value" : 10 }, 
             {"name": "item2", "value" : 20 }
            ]
      };
    $.ajax({
    url : 'chart/graphics',
    type : 'post',
    data : JSON.stringify(json_data),
    contentType : 'application/json;charset=utf-8'  //中文需要加上charset=utf-8才正确
   });

后端写法

  @RequestMapping(value="/{name}", method=RequestMethod.POST, produces="application/json;charset=utf-8;")
  @ResponseBody
  public String postDashboardItem( 
      @PathVariable(value="name") String name,
      @RequestBody String params, 

       Model model) {

   JSONObject object= JSON.parseObject(params);

   //do somthings

   return ""; //json string

}

更正:

感谢alan_waker的提醒,重复做了map接收参数的实验,效果不错。

前端写法一样,

后端写法:

  @RequestMapping(value="/{name}", method=RequestMethod.POST, produces="application/json;charset=utf-8;")
  @ResponseBody
  public String postDashboardItem( 
      @PathVariable(value="name") String name,
      @RequestBody Map<String, Object> params, 

       Model model) {

   //do somthings 
   return ""; //json string

}

需要引用 jackson-databind包,否则前端会报 415错误。后台报Content type 'application/json;charset=UTF-8' not supported。

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

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。