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

相关推荐
大阿明1 分钟前
PostgreSQL常用时间函数与时间计算提取示例说明
java
小糯米6015 分钟前
C++ 并查集
java·c++·算法
IAUTOMOBILE7 分钟前
Code Marathon 项目源码解析与技术实践
java·前端·算法
Flying pigs~~8 分钟前
基于Deepseek大模型API完成文本分类预测功能
java·前端·人工智能·python·langchain·deepseek
Lyyaoo.8 分钟前
【JAVA基础面经】深拷贝与浅拷贝
java·开发语言·算法
oyzz12014 分钟前
Redis 安装及配置教程(Windows)【安装】
java
YNCAH_21 分钟前
特殊类的设计
java·开发语言
商吉婆尼27 分钟前
天地图API调用注意事项
java·spring·天地图
芒果披萨36 分钟前
sql存储过程
java·开发语言·数据库
yaoxin52112342 分钟前
368. Java IO API - 基本文件属性
java·开发语言·python