SpringBoot 4.0.3配置Swagger

1. 引入依赖 (pom.xml)

这是唯一需要的依赖,它包含了自动配置和 UI 界面:

XML 复制代码
<dependency>
        <groupId>org.springdoc</groupId>
        <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
        <version>2.5.0</version>
</dependency>

2. 基础配置 (application.properties)

你可以在配置文件中自定义 Swagger 路径(可选,不配置则使用默认):

bash 复制代码
# 可选:自定义 API 文档路径
springdoc.api-docs.path=/v3/api-docs
# 可选:自定义 Swagger UI 路径
springdoc.swagger-ui.path=/swagger-ui.html

3. 高级配置类 (SwaggerConfig.java)

创建一个配置类,定义文档的头部信息(如标题、作者),并配置文件上传的支持(这是很多人容易忽略的点):

java 复制代码
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.media.Content;
import io.swagger.v3.oas.models.media.MediaType;
import io.swagger.v3.oas.models.media.Schema;
import io.swagger.v3.oas.models.parameters.RequestBody;
import org.springdoc.core.customizers.OperationCustomizer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.multipart.MultipartFile;

@Configuration
public class SwaggerConfig {

    /**
     * 配置 API 文档基本信息
     */
    @Bean
    public OpenAPI customOpenAPI() {
        return new OpenAPI()
                .info(new Info()
                        .title("用户中心 API 文档")
                        .version("1.0")
                        .description("这是一个演示用户信息上传和头像管理的接口文档")
                        .contact(new Contact()
                                .name("开发团队")
                                .email("dev@example.com")));
    }

    /**
     * 【关键】定制化:让 Swagger UI 支持 MultipartFile (文件上传) 的参数展示
     * 如果你有文件上传接口,必须加这个 Bean,否则 Swagger 页面可能不会显示 "Choose File" 按钮
     */
    @Bean
    public OperationCustomizer operationCustomizer() {
        return (operation, handlerMethod) -> {
            // 识别方法中包含 MultipartFile 参数的接口
            if (handlerMethod.getMethodParameters().length > 0) {
                for (var param : handlerMethod.getMethodParameters()) {
                    if (MultipartFile.class.equals(param.getParameterType())) {
                        // 手动构建 RequestBody,强制指定为 multipart/form-data
                        RequestBody requestBody = new RequestBody();
                        Content content = new Content();
                        MediaType mediaType = new MediaType();
                        Schema<?> schema = new Schema<>().type("object");
                        
                        // 这里的属性名要和 Controller 里的 @RequestParam 一致
                        schema.addProperty("username", new Schema<>().type("string").description("用户名"));
                        schema.addProperty("avatar", new Schema<>().type("string").format("binary").description("头像文件"));
                        
                        mediaType.setSchema(schema);
                        content.addMediaType("multipart/form-data", mediaType);
                        requestBody.setContent(content);
                        requestBody.setRequired(true);
                        operation.setRequestBody(requestBody);
                        break;
                    }
                }
            }
            return operation;
        };
    }
}

4. 启动并访问

  1. 启动 Spring Boot 应用。

  2. 打开浏览器访问:

    http://localhost:8086/swagger-ui.html

  3. 你会看到一个漂亮的 UI 界面,找到 /api/user/upload 接口,点击 "Try it out"

  4. 输入 username,并点击 "Choose File" 选择一张图片,最后点击 "Execute" 即可直接在页面上测试接口。

相关推荐
seven97_top2 小时前
NIO:解开非阻塞I/O高并发编程的秘密
java
小六溜了2 小时前
模块二十.双列集合
java
23.2 小时前
【Java】NIO 中的多路复用(Selector / Channel)机制
java·面试·nio
七夜zippoe2 小时前
Docker容器化实战:核心概念、镜像制作与多阶段构建全解析
java·jvm·数据库·docker·oracle·容器化
IT_陈寒2 小时前
JavaScript开发者必知的5个性能杀手,你踩了几个坑?
前端·人工智能·后端
TimberWill2 小时前
优化if else过多的方案(含设计模式处理方式)
java·设计模式
东离与糖宝2 小时前
GraalVM+Project Leyden实战:Spring Boot应用原生编译,Serverless冷启动自由
java·人工智能
今天你TLE了吗3 小时前
JVM学习笔记:第七章——对象实例化、内存布局&访问定位
java·jvm·笔记·学习
w_t_y_y3 小时前
知识体系——MCP(三)io.modelcontextprotocol.sdk(1)开发mcp server
java