http 415 unsupported media type 报错解决方案

背景:系统架构还是用的ssm+bootstrap。前端需要将对象放在list集合中,然后传输到后台进行处理,于是用了

JSON.stringify(batchMaintainBillInfoList)方法将json传到后台直接转化为list
//前端代码
			$('#batchMaintainButton').click(function () {
				var batchMaintainBillInfoList = [];
                $("input[name='billNo']").each(function() {
                    var count = $(this).parent().parent().attr('id');
                    batchMaintainBillInfoList.push({id:$('#id'+count).val(), billNum: $('#billNum'+count).val(), billCode: $('#billCode').val(),
                    								billUser:$('#billUser'+count).val(),billTime: $('#billTime'+count).val(),
                        							remarks: $('#remarks'+count).val(),billImage: $('#billImage'+count).val()});
                });
                if (batchMaintainBillInfoList==null || batchMaintainBillInfoList.length==0){
                    showTip("维护信息不能为空","error" ,2000,0);
                    return false;
				}
                $.ajax({
                    headers: {
                        'Accept': 'application/json',
                        'Content-Type': 'application/json'
                    },
                    type: 'POST',
                    url: '${ctx}/finance/settle/settleBillInfoInvoicing/batchMaintainBillInfoSave',
                    data: JSON.stringify(batchMaintainBillInfoList),
                    success: function (data) {
                        if(data.res_code==1){
                        }else{
                        }
                        top.$.jBox.tip(data.res_desc);
                    },
                    error: function (XMLHttpRequest, textStatus, errorThrown) {
                        top.$.jBox.tip(errorThrown);
                    }
                });
            });
//后端代码
//前端传输的数据,后端可以直接用list集合来接收

    @RequestMapping(value = "batchMaintainBillInfoSave",method = RequestMethod.POST)
    @ResponseBody
    public IntfzResp batchMaintainBillInfoSave(@RequestBody List<BatchMaintainBillInfo> batchMaintainBillInfoList) {
        StringBuffer message = new StringBuffer();

        for (BatchMaintainBillInfo batchMaintainBillInfo : batchMaintainBillInfoList) {
            try {
                
            }catch (Exception e){
               
                
            }
        }
            if (StringUtils.isBlank(message.toString())){
                message.append("批量维护发票信息完成");
            }
        return IntfzResp.resSuccess(message.toString());
    }

提交请求之后页面报错http 415 unsupported media type,由于是第一次用JSON.stringify(batchMaintainBillInfoList)这种方式,总是以为自己这里写错了,而且百度一下,发现好多用我这个方法导致415的,就更加确定了是因为这个原因导致415的。

后来请教同事,同事让我把我的提交部分逻辑给注释掉,发现没有提交的时候还是会报这个错误。

于是想到我的点击按钮的类型,是submit

<input id="batchMaintainButton" class="btn btn-primary" type="submit" value="保 存"/>

当type是submit时会直接将表单提交,但是我后台接收参数的话,是没有办法这样直接将表单接收下去的,需要处理一下,所以导致报错415,后台服务无法解析。后来我将type改为button就好了。

PS:这个bug启发了我一个思路:发现问题的时候,先要确定是什么导致bug,而不是盲目觉得哪里不熟,肯定是哪里的问题云云,这个问题,很简单,但是花费了我很久的时间,觉得很浪费。思路还是要开阔一些。

这个帖子希望能够帮到大家。每天进步一点!大家共勉!加油!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值