API请求报错 Required request body is missing问题解决

背景

在进行调用的时候,加载方法,提示以下错误

错误信息如下:

javascript 复制代码
{
    "code": 10001,
    "msg": "Required request body is missing:  XXX",
    "data": null,
    "extra": null
}

Required request body is missing 错误通常表明服务器期望在 POST 请求的正文中接收到一些数据,但是实际上没有接收到。这可能是因为客户端没有发送正确的请求体,或者是因为服务器端的配置有问题。

所以根据前后端分别拆分校验定位。

解决过程

1、后端接口验证

使用PostMan直接调用接口。没有发现问题。数据可以正常返回。

PostMan是一个模拟接口调用的工具。具体可以自行百度。

2、前端验证

PostMan可以正常返回数据了。

所以,真相只有一个,那就是前端问题了。

2.1 传输参数定位

代码如下:

javascript 复制代码
apiMethod(this.queryParams).then((response) => {
//业务代码
}

this.queryParams的定义如下:

javascript 复制代码
// 查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        due: undefined,
        status: undefined,
        start: undefined,
        end: undefined,
      },

打印参数也OK。

2.2 参数格式问题

后端形参是一个对象,使用的@RequestBody的Post方式。所以应该也不会有问题。

如是,我想了下,是不是传递参数的过程中没有格式化json格式导致的问题。(死马当活马医,因为我用POstman去跑的时候,用的是JSOn格式)

于是我修改为apiMethod(JSON.stringify(this.queryParams))方式,调用的时候发现还是不OK。

如果参数没问题,那么就是传输的时候的问题了,我猜测问题应该是在远程调用的时候的问题。

于是找到JS的方法的api定义方法:

javascript 复制代码
export function apiMethod(query) {
  return request({
    url: "XXXX",
    method: "post",
    query,
  });
}

2.3 传输定义

我把其中的query修改为data:query。然后重新调试,发现问题解决了。

代码如下:

javascript 复制代码
export function apiMethod(query) {
  return request({
    url: "XXXX",
    method: "post",
    data: query,
  });
}

伪代码

后端Controller层:

java 复制代码
@RestController  
@RequestMapping("/api")  
public class MyController {  
  
    @PostMapping("/someEndpoint")  
    public ResponseEntity<String> handlePostRequest(@RequestBody MyVO vo) {  
        // 处理 vo 对象  
        return ResponseEntity.ok("Received request with VO object");  
    }  
}

前端代码:

javascript 复制代码
export function apiMethod(query) {
  return request({
    url: "XXXX",
    method: "post",
    data: query,
  });
}

分析总结

根据实际情况,一般定位这种问题参考以下几点来进行排除:

  • 客户端请求: 客户端必须发送一个包含请求体的 POST 请求。请求体应该是一个 JSON 字符串,其结构与 MyVO 类的字段相匹配。

  • Content-Type: 确保客户端在请求头中设置了正确的 Content-Type,通常为 application/json。

  • VO 类定义: VO 类应该与 JSON 数据中键的字段相对应,并且这些字段应该有正确的 getter 和 setter 方法。如果有任何不匹配,Spring MVC 将无法正确地将 JSON 数据绑定到 VO 对象。

  • Spring 配置: 确保 Spring 应用已经配置了用于处理 JSON 的消息转换器,例如 MappingJackson2HttpMessageConverter。这通常是通过在类路径上有 Jackson 相关的依赖项自动配置的。

  • 异常处理: 检查你的控制器是否有任何异常处理逻辑,它可能会捕获并处理这个错误,而不是将其返回客户端。

基本上使用上面几点来做排除法,问题都能进行解决。如果你已经检查了上述所有点,但问题仍然存在,那么需要查看更详细的日志信息,或者调试 Spring MVC 控制器以查看在何处丢失了请求体。

相关推荐
lybugproducer2 小时前
创建型设计模式之:简单工厂模式、工厂方法模式、抽象工厂模式、建造者模式和原型模式
java·设计模式·建造者模式·简单工厂模式·工厂方法模式·抽象工厂模式·面向对象
南客先生2 小时前
马架构的Netty、MQTT、CoAP面试之旅
java·mqtt·面试·netty·coap
Minyy112 小时前
SpringBoot程序的创建以及特点,配置文件,LogBack记录日志,配置过滤器、拦截器、全局异常
xml·java·spring boot·后端·spring·mybatis·logback
百锦再2 小时前
Java与Kotlin在Android开发中的全面对比分析
android·java·google·kotlin·app·效率·趋势
武昌库里写JAVA3 小时前
39.剖析无处不在的数据结构
java·vue.js·spring boot·课程设计·宠物管理
Nelson_hehe5 小时前
Java基础第四章、面向对象
java·语法基础·面向对象程序设计
Thomas_YXQ5 小时前
Unity3D Lua集成技术指南
java·开发语言·驱动开发·junit·全文检索·lua·unity3d
ShiinaMashirol6 小时前
代码随想录打卡|Day27(合并区间、单调递增的数字、监控二叉树)
java·算法
东阳马生架构8 小时前
Nacos简介—3.Nacos的配置简介
java
北极的企鹅888 小时前
XML内容解析成实体类
xml·java·开发语言