解决 Content type ‘application/json;charset=UTF-8‘ not supported

devtools/2024/9/24 7:24:36/

文章目录

  • 问题描述
  • 原因分析
  • 解决方案
  • 参考资料


在这里插入图片描述


问题描述

我项目前端采用vue-elementUi-admin框架进行开发,后端使用SpringBoot,但在前后端登录接口交互时,前端报了如下错误

在这里插入图片描述完整报错信息如下

在这里插入图片描述

前端登录接口JS代码如下

export function login(data) {return request({url: '/users/login',method: 'post',headers: {'Content-Type': 'application/json;charset=UTF-8'},data})
}

后端登录接口相应代码如下

java">	@PostMapping("/login")public HttpResult login(@RequestBody UsersDto usersDto) {System.out.println("usersDto = " + usersDto);Map<String, String> map = new HashMap<>();map.put("token", "admin-token");return HttpResult.ok(map);}

在这里插入图片描述

在这里插入图片描述


原因分析

众所周知,@RequestBody主要用来 接收前端传递给后端的json字符串中的数据的(请求体中的数据的),然后Spring Mvc就会将该数据装配到目标类(@RequestBody后面的类)中;而GET方式无请求体,所以使用@RequestBody接收数据时,前端不能使用GET方式提交数据,而是用POST方式进行提交。

但是,请注意“装配”的过程中会根据json字符串中的key来匹配对应实体类的属性如果匹配一致且json中的该key对应的值的类型符合(或可转换为“”或null)

Trips

  • 前端json字符串中,如果value为"“的话,后端实体类对应的属性如果是String类型时,那么接受到的就是”"
  • 如果是后端实体类的属性类型是Integer、Double等类型,那么后端接收到的就是null
  • json字符串中,如果value为null的话,后端实体类对应属性接收的就是null

基于上述分析,排查前端携带的参数与后端的接收类时后发现,报错的原因是 前端传过来的json字符串中的key与后端的接受类(使用@RequestBody修饰的类)属性名不一致,无法将key映射到实体类的属性中

前端登录接口携带参数如下

在这里插入图片描述
后端目标类的属性如下

在这里插入图片描述


解决方案

后端目标类的属性名和前端json字符串对应的key保持一致

在这里插入图片描述


参考资料

  • @RequestBody的详解和使用

http://www.ppmy.cn/devtools/42172.html

相关文章

力扣HOT100 - 295. 数据流的中位数

解题思路&#xff1a; 小顶堆 大顶堆 class MedianFinder {Queue<Integer> A, B;public MedianFinder() {A new PriorityQueue<>();B new PriorityQueue<>((x, y) -> (y - x));}public void addNum(int num) {if (A.size() ! B.size()) {A.add(num);B…

C#知识|上位机子窗体嵌入主窗体方法(实例)

哈喽,你好啊,我是雷工! 上位机开发中,经常会需要将子窗体嵌入到主窗体, 本节练习C#中在主窗体的某个容器中打开子窗体的方法。 01 需求说明 本节练习将【账号管理】子窗体在主窗体的panelMain容器中打开。 账号管理子窗体如下: 主窗体的panelMain容器位置如图: 02 实现…

申请 meta llama 模型权重(超详细)

文章目录 1、github访问meta的llama项目2、查看github项目下的README.md3、填写申请信息&#xff08;注意邮箱要与huggingface账户邮箱一致&#xff09;4、查看邮箱的邮件并了解下载教程&#xff08;方案一&#xff09;5、Meta website 查看下载教程 &#xff08;同方案一&…

使用Docker配置深度学习环境——以diffusers为例

Docker的其他信息可以在我的网站上找到&#xff0c;这里假设安装完成了&#xff0c;直接上手。 git clone 仓库地址打开docker目录&#xff0c;找到目标版本&#xff1a; sudo docker build diffusers-pytorch-cuda如果失败&#xff0c;尝试使用换源&#xff1a; sudo nano …

第02章 计算机网络概述

2.1 本章目标 了解计算机网络的定义了解计算机网络的功能了解计算机网络的分类了解计算机网络的组成 2.2 计算机网络的定义 2.3 计算机网络的功能 2.4 计算机网络的分类 物理拓扑结构分类&#xff1a;总线型、环型、星型 2.5 计算机网络的组成 网络适配器(NIC)接口规格分类&a…

【硬件模块】ESP-01SWiFi模块基于AT指令详解(WiFi,TCP/IP,MQTT)

ESP-01S ESP-01S是由安信可科技开发的一款Wi-Fi模块。其核心处理器是ESP8266&#xff0c;该处理器在较小尺寸的封装中集成了业界领先的Tensilica L106超低功耗32位微型MCU&#xff0c;带有16位精简模式&#xff0c;主频支持80MHz和160MHz&#xff0c;并集成了Wi-Fi MAC/BB/RF/P…

linux实用命令

一、常用命令 mkdir -p mkdir -p 命令用于在Unix和Linux系统中创建目录。其中&#xff0c;-p参数确保目录名称存在&#xff0c;如果目录不存在的就新创建一个。换句话说&#xff0c;-p参数允许创建一个目录和它不存在的父目录&#xff0c;确保了指定的整个目录路径都会被…

winform,子线程里messagebox如何模态阻止ui线程

在WinForms中&#xff0c;如果你想在子线程中显示一个MessageBox并阻止UI线程&#xff0c;可以使用Invoke或BeginInvoke方法来确保MessageBox是在UI线程上显示的。这是因为WinForms控件不是线程安全的&#xff0c;所有的UI操作都应该在UI线程上进行。 以下是一个示例代码&…