Unsupported Media Type 415问题解决办法(Ajax)

Posted 迷失之路

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Unsupported Media Type 415问题解决办法(Ajax)相关的知识,希望对你有一定的参考价值。

场景:Ajax传一个json对象到服务器,让参数自动封装至与json对象匹配的java对象中。

 

错误类型

  • 错误类型1:

"status":415

"error":"Unsupported Media Type"

"exception":"org.springframework.web.HttpMediaTypeNotSupportedException"

原因:没有使用JSON.stringify(rowData)方法将请求参数转化为json字符串

 

  • 错误类型2:

"status":400

"error":"Bad Request"

"exception":"org.springframework.http.converter.HttpMessageNotReadableException"

原因:未使用[contentType : \'application/json\',]配置指定请求参数格式。

 

正确代码

  js代码:

  rowData:是easyui datagrid表格的一行数据,和服务器的一个java类Condition对象属性完全匹配。
JSON.stringify(rowData):将rowData对象解析成字符创。
            $.ajax({
                type : \'PUT\',
                url : url,
                dataType : \'json\',
         contentType : \'application/json\',
data : JSON.stringify(rowData), beforeSend : function () { // .... }, success : function (data) { // 返回的RequestResult的json对象 console.log(data); }, });

  spring boot Controller 接收参数的 java代码:

    @RequestMapping(value = "/test", method = RequestMethod.PUT)
    public @ResponseBody RequestResult modifyCondition(@RequestBody Condition condition) {
        System.out.println("condition:" + condition.toString());
        // 创建假返回数据
        RequestResult result = new RequestResult();
        result.setCode(0);
        result.setMessage("success");
        return result;
    }

    返回结果:

以上是关于Unsupported Media Type 415问题解决办法(Ajax)的主要内容,如果未能解决你的问题,请参考以下文章

angularjs - 415 (Unsupported Media Type)

RestTemplate - 415 UNSUPPORTED_MEDIA_TYPE 错误

Ajax请求(415 Unsupported Media Type)

post 请求数据返回 Unsupported Media Type

Unsupported Media Type 415问题解决办法(Ajax)

SpringMVC---REST POST时出现415 Unsupported Media Type