最近使用ajax接收spring mvc傳過來的json數據時總是出現parseerror的錯誤,錯誤源碼如下:
前端:
$.ajax({
type: 'POST',
url: "groupFunctionEdit",
dataType: 'json',
contentType: "application/json",
data: JSON.stringify(functiondata),
success: function(data){
alert('數據加載成功'+data.msg);
},
error: function(xhr, type){
alert('數據加載失敗');
console.log(type);
}
后臺Controller:
@RequestMapping("/groupFunctionEdit")
public @ResponseBody Object groupFunctionEdit(@RequestBody ListYyGroupFunction> yyGroupFunctionList) throws JsonProcessingException{
return "success";
}
查詢資料發現有如下解答:
當使用簡單類型即:String這樣的類型來接收數據時,不需要使用@RequestBody這個注解。
這里需要使用spring mvc處理json的依賴jar包:jackson.databind.jar
解決辦法:
前端不用修改,在后臺對需要的數據進行map封裝再轉化為String類型:
@RequestMapping("/groupFunctionEdit")
public @ResponseBody Object groupFunctionEdit(@RequestBody ListYyGroupFunction> yyGroupFunctionList) throws JsonProcessingException{
MapString,Object> map = new HashMapString,Object>();
map.put("msg", "success");
ObjectMapper mapper = new ObjectMapper();
String msg = mapper.writeValueAsString(map);
return msg;
}
這樣傳到前端的數據變成了:
再使用jQuery可以解析到,不會報錯。
以上所述是小編給大家介紹的解決spring mvc 返回json數據到ajax報錯parseerror問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
您可能感興趣的文章:- Ajax跨域問題及解決方案(jsonp,cors)
- Springboot解決ajax+自定義headers的跨域請求問題
- 淺談Koa2框架利用CORS完成跨域ajax請求
- php獲取ajax的headers方法與內容實例
- Javaweb使用cors完成跨域ajax數據交互
- jQuery.Form實現Ajax上傳文件同時設置headers的方法
- Servlet 與 Ajax 交互一直報status=parsererror的解決辦法
- 完美解決ajax跨域請求下parsererror的錯誤
- jQuery.ajax 跨域請求webapi設置headers的解決方案
- Jax-rs規范REST接口文件上傳代碼實例