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

时间:2021-05-19

关于@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。

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

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章