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