spring boot 2.2.6 以上版本 错误:HttpMessageNotReadableException: Required request body is missing

本文探讨了在升级到SpringBoot 2.2.13后,遇到的Postman接口测试中HttpMessageNotReadableException问题,原因在于Content-Type设置问题。解决方法是确保Content-Type设置为'application/json',并分享了如何在Postman中避免自动添加charset。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目升级使用spring boot 2.2.13 ,在使用postman测试接口时报错:HttpMessageNotReadableException: Required request body is missing

在自己的controller的接口里接收不到body数据, 示例代码如下:

    @PostMapping(value = "/java/test/findByPage")
    public Object findByPage(@RequestBody FilterVo filterVo) {
        try {
            logger.info(" findByPage  filterVo{}", filterVo);
           return "";
        } catch (Exception e) {
            logger.error("------", e);
            return e;
        }
    }

造成这个错误的原因是在请求的头部的 Content-Type 参数造成的。

postman 的自动设置这个参数为:"application/json;charset=UTF-8"  ,即使你设置成  "application/json",在请求时也会变成前面的那个。所以spring boot 并没有识别,没有给转换。

解决办法:

 "Content-Type"  设置成 "application/json",请求接口正常。

   至于postman[8.0.6]如何设置不自动增加"chartset=UTF-8",还请高手留言!

另外为什么提到spring boot的版本,因为在2.2.6的时候并没有发现这个问题。至于在哪个小版本中改成这样的,本人未知。

### 关于 `spring-boot-starter-aop` 版本 2.2.6 的文档和使用 对于 `spring-boot-starter-aop` 版本 2.2.6,在 Maven 中配置该依赖项的方式如下所示: ```xml <dependencies> <!-- Spring Boot Starter AOP --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> <version>2.2.6.RELEASE</version> </dependency> </dependencies> ``` 此版本的引入使得开发者可以在基于 Spring Boot 的应用程序中轻松集成面向切面编程(AOP)[^1]。 为了更好地理解和应用这个版本中的特性,建议熟悉一些基础概念。这有助于更清晰地掌握如何利用这些工具来增强代码的功能性和可维护性[^2]。 当在项目中具体实施时,可以参照官方文档或其他资源学习更多细节。例如,定义切入点表达式、编写通知(Advice)逻辑等操作均可以通过查阅相关资料获得指导[^3]。 下面是一个简单的例子展示如何在一个控制器内设置日志记录方面的能力,这里采用的是带有特定异常处理的日志输出方式作为示范[^4]: ```java import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @Aspect public class LoggingAspect { private static final Logger logger = LoggerFactory.getLogger(LoggingAspect.class); @Before("execution(* com.example.demo.controller..*.*(..))") public void logMethodCall() { logger.info("Logging method call"); } } ``` 上述代码片段展示了如何通过自定义切面类来进行方法调用前后的日志记录工作。 #### 配置文件调整 如果希望进一步定制化行为,则可能需要修改项目的配置文件(application.properties 或 application.yml),比如指定某些包下所有的组件都应被纳入扫描范围之内: ```yaml spring: aop: auto: true ``` 这样做的目的是让框架自动识别并注册所有符合条件的通知器(advisor),从而简化开发流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值