通過Ajax進行Post提交Json數據的方法
js代碼
$.ajax({ type : "POST", url : js_path + "/maintainAdd/add", data : JSON.stringify(madd_data.editMaintain), contentType : "application/json", dataType : "json", complete:function(msg) { layer.msg("報修成功",{time:2000}); layer.close(madd_data.w_c_index); } });
Action代碼
<span style="white-space:pre;"> </span>@ResponseBody @RequestMapping(value = "/add",method = RequestMethod.POST) public void addMaintain(@RequestBody Maintain maintain){ this.save_maintain(maintain); }
注意事項:
1、ajax中,contentType: "application/json"是必須的。dataType: "json"是表示返回值是json格式,依據返回值類型而定。
2、data中,將json對象序列化。使用JSON.stringfy()函數或者雙引號形式的字符串。
3、調試的一個技巧,有時候json變量和實體類相對復雜時提交老是報415或者400的錯誤又找不到原因,可以將Action中的實體類換成JSONObject 看看能不能接收到參數,@RequestBody JSONObject requestJso,接收后在JSON系列化到實體類。有次就是因為json變量向實體類轉換時發(fā)生字符向數字轉換的錯誤。
以上這篇通過Ajax進行Post提交Json數據的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
編寫輕量ajax組件01-與webform平臺上的各種實現方式比較
這篇文章主要介紹了編寫輕量ajax組件01-與webform平臺上的各種實現方式比較,需要的朋友可以參考下2015-11-11AJAX 常用函數創(chuàng)建XMLHTTP對象,區(qū)別IE,Mozilla瀏覽器
AJAX 常用函數創(chuàng)建XMLHTTP對象,區(qū)別IE,Mozilla瀏覽器...2007-10-10