前端向后端传参报415_Ajax向后台传json格式的数据出现415错误的原因分析及解决方法...

问题描述:

ajax往后台传json格式数据报415错误,如下图所示

页面代码

function saveUser(){

var uuId = document.getElementById("uuid").value;

var idCard = document.getElementById("idCard").value;

alert(uuId+idCard);

// var result = new Object();

// result.uuId = uuId;

// result.idCard = idCard;

// var saveData = JSON.stringify(result);

// alert(saveData);

$.ajax({

url : "xdds/saveUser.do?random=" + Math.random(),

type : "post",

data : {"uuid" : uuId,"idCard" : idCard},

// data:saveData,

dataType : 'json',

// contentType : "application/json",

success:function(data){

}

});

}

后台代码

@RequestMapping(value = "/saveUser.do", method = { RequestMethod.POST })

@ResponseBody

public Map saveUser (@RequestBody MapUser user){

Map map = new HashMap();

System.out.println(user.getUuid()+user.getIdCard());

map.put("result", "fda");

return map ;

}

错误分析:415 (不支持的媒体类型) 请求的格式不受请求页面的支持

正确的json格式{key:value, key:value}key和value应该都带双引号。上面的前台代码data中的数据value不带双引号,所以导致报错(因为前面接触的项目这样写是没问题)

所以初步分析可能应为框架的问题,有的框架可以将

data : {"uuid" : uuId,"idCard" : idCard}这种封装成正确的json格式。

具体原因还不知道,博主也是小白,等博主搞清楚会分享出来的

解决办法:将前台注释的代码打开

var saveData = JSON.stringify(result)
这个函数可以转化成真确的json格式。
ps:小白一个,有不对的地方请大神指正;有大神知道具

以上所述是小编给大家介绍的Ajax向后台传json格式的数据出现415错误的原因分析及解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值