版权声明
- 本文原创作者:谷哥的小弟
- 作者博客地址:http://blog.csdn.net/lfdfhl
问题描述
使用 AJAX + SpringBoot 前后端交互时,Java后台报错:
Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported
图示如下:
为了进一步核实错误,在浏览器控制台查看了请求头。
图示如下:
问题小结:
前端发送的数据不是后端所期望的JSON格式数据。
问题剖析
我们在开发过程中需注意JSON数据的不同类型。
- 1、JSON对象类型。当前端定义的contentType为 application/x-www-form-urlencoded时前端传递至后台的数据为JSON对象;此时,Java后台采用@RequestParam接收前端传递的JSON数据。
- 2、JSON字符串类型。当前端定义的contentType为application/json时前端传递至后台的数据为JSON字符串;此时,Java后台采用@RequestBody接收前端传递的JSON数据。
解决方案
在前端AJAX请求中设置contentType、data、dataType。
要点概述:
- 1、data:客服端发送至后台的JSON字符串数据
- 2、contentType:告知服务器客户端发送的数据的格式
- 3、 dataType:告知服务端客户端期望收到的数据为何种格式
"contentType": "application/json;charset=utf-8",
"data":JSON.stringify(param),
"dataType": "json",