Knife4j 文件上传 multipart/data 同时接受文件和对象,调试时上传文件失效

复制代码
PrizeCreateParam 自定义的java对象 还有 MultipartFile

当二者同时使用RequestPart注解后, 按理来说 knife4j页面应该是 可以显示 文件上传和json填写的

这里prizePic的请求类型是Query显然是错的,因为文件上传不能在url里面

我的knife4j是 4.4.0版本

复制代码
<dependency>
   <groupId>com.github.xiaoymin</groupId>
   <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
   <version>4.4.0</version>
</dependency>

AI的核心修改思路是:

通过 Swagger 注解明确声明每个参数的媒体类型,让 Knife4j 知道「哪个参数是文件、哪个参数是 JSON 对象」,但是AI修改后 主要是 使用Parameter注解,而且生成的代码修改非常长,给接口补充精准的 OpenAPI 3 注解,明确标记每个参数的类型和媒体类型

解决方案:

无意在GitHub上发现了个大佬的解决方案,虽然不是很完美,但是用了很少的代码就 实现了原本的功能

经过试验发现确实是有效的

但是最终展示出的效果 并不是以JSON格式的填写,而是以FROM表单格式的填写方式

可以肯定的是这个就是BUG

Knife4j 4.x 对 OpenAPI3 的 multipart 解析问题 :当接口使用 @RequestPart JSON对象 + @RequestPart MultipartFile

springdoc 生成的 OpenAPI 是正确的(multipart/form-data 下的 object schema)

原生 Swagger UI 能正常显示"文件选择按钮 + JSON 输入框";

但 Knife4j 在二次解析文档时,没有把 JSON 对象正确放进 multipart 的 schema 里,而是当成普通 body 或参数处理,导致文件类型被降级成文本框或变成 raw/query 参数

所以表现异常------不是你的 Controller 写错,而是 Knife4j 4.x 的解析兼容问题。

相关推荐
庞轩px12 小时前
第七篇:Spring扩展点——如何优雅地介入Bean的创建流程
java·后端·spring·bean·aware·扩展点
tongluowan00713 小时前
一个请求在Spring MVC 中是怎么流转的
java·spring·mvc
夜郎king14 小时前
Spring AI 对接大模型开发易错点总结与实战解决办法
java·人工智能·spring
oradh14 小时前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
组合缺一14 小时前
Java AI 框架三国杀:Solon AI vs Spring AI vs LangChain4j 深度对比
java·人工智能·spring·ai·langchain·llm·solon
c++之路14 小时前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌15 小时前
Java——接口的细节
java·开发语言·算法
阿拉金alakin15 小时前
深入理解 Java 锁机制:CAS 原理、synchronized 优化与主流锁策略全总结
java·开发语言
myheartgo-on15 小时前
Java—方 法
java·开发语言·算法·青少年编程
雨落在了我的手上15 小时前
如何学习java?
java·开发语言·学习