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 的解析兼容问题。

相关推荐
磊磊落落21 分钟前
如何将 Spring Statemachine 作为一个轻量级工作流引擎来使用?
java
兆子龙14 小时前
ahooks useRequest 深度解析:一个 Hook 搞定所有请求
java·javascript
兆子龙14 小时前
React Suspense 从入门到实战:让异步加载更优雅
java·javascript
咕白m62517 小时前
Java 实现 Excel 转 HTML:完整示例
java
RealPluto17 小时前
Spring AOP 失效排查
java·spring
码路飞18 小时前
热榜全是 OpenClaw,但我用 50 行 Python 就造了个桌面 AI Agent 🤖
java·javascript
Nyarlathotep011318 小时前
LinkedList源码分析
java·后端
用户83071968408218 小时前
Java 告别繁琐数据统计代码!MySQL 8 窗口函数真香
java·sql·mysql
带刺的坐椅18 小时前
SolonCode v0.0.20 发布 - 编程智能体(新增子代理和浏览器能力)
java·ai·agent·solon·solon-ai·claude-code·openclaw