廢話不多說,上代碼
后端接收對象:
class ObjectA{ private String a; private String b;
private List<ObjectB> list; //getter/setter }
class ObjectB{ private String a; private String b; //getter/setter }
Controller對應的method
@PostMapping("/getParam") public String getParam(@RequestBody ObjectA objectA){ log.info("objectA:{}", objectA.toString()); return "success"; }
使用@RequestBody注解是指定接收數據為json格式 .
后端處理好了,前端又該如何處理呢?
function sendAjax(){ var list = new Array({"a":"ObjectB參數a-1", "b":"ObjectB參數b-1"},{"a":"ObjectB參數a-2", "b":"ObjectB參數b-2"}); var obj={"a":"ObjectA參數a", "b":"ObjectA參數b", "list":list} console.info(obj) $.ajax({ url:"/getParam", type:"POST", data: JSON.stringify(obj),//1.4+以上的jquery版本對json格式要求更加嚴格.如果不是嚴格的json格式,就不能正常執行success回調函數. contentType:"application/json; charset=utf-8",//設置請求頭,默認方式是application/x-www-form-urlencoded; charset=UTF-8 dataType:"json", success: function(data){ alert(data); } }); }
如面的請求代碼所示,
① 設置請求頭內容格式,應為jquery的$.ajax({})默認的ContentType的值為:application/x-www-form-urlencoded; charset=UTF-8,它無法被 @RequestBody 解析格式串
② 傳到后台的參數最好使用 JSON.stringify()處理一下。防止后端無法解析該對象,報“ JSON parse error: Unrecognized token 'a': was expecting ('true', 'false' or 'null') ”
這邊附上 ① 的解釋說明:https://blog.csdn.net/Tiglle/article/details/75269171
② 的解釋說明:https://blog.csdn.net/qq_36802726/article/details/88419297