关于解决新版本spring项目请求测试接口返回406的问题

目录

一、问题产生

二、问题排查

(1)首先是打断点debug进行排查

(2)网上查找相关资料排查

(3)老项目测试

三、问题解决


一、问题产生

使用Apifox对后端发送请求进行接口测试时返回状态码406,查看后端日志

2025-03-15T19:56:40.747+08:00 WARN 18108 --- [management_system] [nio-8080-exec-4] .w.s.m.s.DefaultHandlerExceptionResolver:Resolved[org.springframework.web.HttpMediaTypeNotAcceptableException: No acceptable representation]

这个问题导致前端并未获得后端应该返回的数据,所以我搜索了一些相关资料,并开始进行问题原因排查。

二、问题排查

(1)首先是打断点debug进行排查

从上面可以看到,我们的deptList是有数据的,说明service层和dao层的执行逻辑应该没有太大问题。

接着我在result包装类中打了断点,想看看depList时候被赋值到了data属性中,从图中可以看到size=6,是拿到了数据的

接着步过的时候进入了字节码文件,虽然我到这看不太懂了,但是我看到了getBean,那可能和对象的管理有关系。(后续步入的话就是更深的源码,就不演示了)

(2)网上查找相关资料排查

接着我在网上搜索了springboot项目中406的相关解决办法,然后我挨个进行了尝试,首先是请求头的Accept配置,网上说没有配置json格式数据就会出现问题,我查看了我的配置,发现我这边默认就是都能接收的,所以不是这个问题

然后还有一种说法是没有给包装类配置getter 和setter注解,我这边是导入了lombok依赖的,写了@Data注解,所以这个因素也排除掉。

然后我尝试了不使用包装类,直接将返回值改为null,我发现是正常的,没有出现问题。

到这里我判断是包装类里面出现了相应的问题。

(3)老项目测试

我打开了之前已经完成了的springboot项目,我开始测试接口,发现并没有出现什么问题,并对照了相应的代码部分编写,没有本质区别。这里的话,我想到了,是不是spring版本更新升级,导致了老方法,老配置不行?

三、问题解决

在查阅资料和spring官方文档后,我发现Spring官方进行了升级, 在创建项目时添加lombok依赖的话, 会自动引入一个插件(之前没有, 新增的), 把这个插件删了就可以了。不然的话@Data没有生效,包装类那里就会出现问题。然后,刷新maven, clean, compile,就可以了。

最后进行接口测试发现能够正常的返回数据了

以上就是我解决请求406状态码的步骤和思路,希望对你有所帮助!可以的话给个点赞收藏吧!

相关推荐
Hellyc2 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen2 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
hdsoft_huge2 小时前
SpringBoot 与 JPA 整合全解析:架构优势、应用场景、集成指南与最佳实践
java·spring boot·架构
Livingbody3 小时前
基于【ERNIE-4.5-VL-28B-A3B】模型的图片内容分析系统
后端
百锦再3 小时前
详细解析 .NET 依赖注入的三种生命周期模式
java·开发语言·.net·di·注入·模式·依赖
程序员的世界你不懂3 小时前
基于Java+Maven+Testng+Selenium+Log4j+Allure+Jenkins搭建一个WebUI自动化框架(2)对框架加入业务逻辑层
java·selenium·maven
你的人类朋友4 小时前
🍃Kubernetes(k8s)核心概念一览
前端·后端·自动化运维
有没有没有重复的名字4 小时前
线程安全的单例模式与读者写者问题
java·开发语言·单例模式
追逐时光者5 小时前
面试第一步,先准备一份简洁、优雅的简历模板!
后端·面试
慕木兮人可5 小时前
Docker部署MySQL镜像
spring boot·后端·mysql·docker·ecs服务器