SpringBoot项目集成Smart-Doc的实战指南

 更新时间:2025年10月24日 08:49:28   作者:Micro麦可乐  
Smart-Doc是一款强大的基于Java的API文档生成工具,它通过对接口源代码进行分析来生成全面而准确的文档,完全不需要对代码进行任何注入,下面我们看看如何在SpringBoot项目中集成Smart-Doc吧

为什么我放弃了SpringDoc OpenAPI

在我们开发 Spring Boot 项目中,相信很多小伙伴最初都是选择 SpringDoc OpenAPI (Swagger3) 来生成接口文档。博主之前也写了一篇整合SpringDoc OpenAPI的文章,感兴趣的可以查阅 SpringBoot3整合SpringDoc OpenAPI生成接口文档的详细过程

SpringDoc OpenAPI 它可以通过注解自动生成交互式文档(Swagger UI),你是不是觉的也挺方便挺好的,实际上当项目规模逐渐增大、功能需求不断更新后,你就会慢慢发现以下这类问题:

1、代码侵入性强

需要大量 @Schema@Operation@ApiResponse 等注解来完善文档,增加代码耦合和维护负担!

常见的注解示例如下:

当业务功能有所调整,我们也需要一并对注解进行修改

import com.toher.springdoc.bean.User;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.media.Content;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.responses.ApiResponse;
import io.swagger.v3.oas.annotations.responses.ApiResponses;
import org.springframework.web.bind.annotation.*;

/**
 * @Author 麦可乐
 * @Date 2025/10/20 11:17 AM
 * @Version 1.0
 */

@RestController
@RequestMapping("/api/users")
public class UserController {

    @Operation(summary = "获取用户信息接口", description = "通过用户ID获取用户信息")
    @ApiResponses(value = {
            @ApiResponse(responseCode = "200", description = "用户信息",
                    content = {@Content(mediaType = "application/json",
                    schema = @Schema(implementation = User.class))}),
            @ApiResponse(responseCode = "404", description = "无法获取用户信息")
    })
    @GetMapping("/{id}")
    public User getUserById(@Parameter(description = "用户ID") @PathVariable Long id) {
        //模拟数据库获取用户
        User user = new User();
        user.setId(1L);
        user.setName("张三");
        user.setEmail("zhansan@qq.com");
        return user;
    }
}

2、运行依赖问题

目前大多数企业都是前后端协同开发的,而SpringDoc OpenAPI 生成接口文档依赖项目运行环境(即需要 Spring 启动),意味着文档无法离线生成,CI/CD 集成麻烦。

3、多模块支持问题

很多时候我们的项目都是基于多模块的,如一个 SpringBoot 项目中包含了前端API模块和后端API模块,那么我们分别就需要启动前端API服务和后端API服务,SpringDoc 很难整合多个模块接口,需要手动聚合

Smart-Doc 的出现:让接口文档真正无侵入

直到博主发现了Smart-Doc,它最大的特点是——无需启动项目、无需注解,通过静态源码分析生成接口文档,官方文档地址:https://smart-doc-group.github.io/zh/

Smart-Doc核心特点

  • 零侵入:完全基于注释信息生成文档,实现代码零侵入
  • 接口多样性:支持为Java RESTful API、Java WebSocket、Apache Dubbo RPC和gRPC接口生成文档
  • 框架多样性:支持 Spring Boot、JAX-RS、Solon等多种框架
  • 文档丰富:支持生成 HTML、Asciidoc、Markdown、OpenAPI、Swagger、Postman、Word 等多种格式的文档
  • 支持拓展:支持用户使用 Java SPI 对支持框架进行扩展
  • 文档协作管理:Smart-Doc 和 Torna 结合形成行业领先的文档解决方案

SpringBoot快速整合smart-doc

为了让大家迅速掌握smart-doc,我们先从最简单的单模块 Spring Boot 项目开始

项目结构示例

小伙伴们自行构建SpringBoot项目,博主的项目结构如下:

添加 Maven 插件

在 pom.xml 中加入 Smart-Doc 插件配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.5.7</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.toher</groupId>
    <artifactId>smart-doc-demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>smart-doc-demo</name>
    <description>smart-doc-demo</description>

    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>

            <plugin>
                <groupId>com.ly.smart-doc</groupId>
                <artifactId>smart-doc-maven-plugin</artifactId>
                <version>3.1.1</version>
                <configuration>
                    <configFile>./src/main/resources/smart-doc.json</configFile>
                    <projectName>${project.description}</projectName>
                </configuration>
                <executions>
                    <execution>
                        <!--如果不需要在执行编译时启动smart-doc,则将phase注释掉-->
                        <phase>compile</phase>
                        <goals>
                            <!--smart-doc提供了html、openapi、markdown等goal,可按需配置-->
                            <goal>html</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>

添加Smart-Doc配置文件

本文主要给大家演示如何快速接入Smart-Doc,更多配置文件项说明请参考官方文档 https://smart-doc-group.github.io/zh/guide/advanced/config

在resources目录下创建smart-doc.json

{
  "outPath": "src/main/resources/static/doc",
  "projectName": "SmartDoc Demo",
  "allInOne": true,
  "serverUrl": "http://localhost:8080",
  "packageFilters": "com.toher.smartdocdemo.controller",
  "sourceCodePaths": [
    {
      "path": "src/main/java",
      "desc": "Main Source"
    }
  ]
}

编写实体类User

/**
 * 用户实体类
 *
 * @Author: micro麦可乐
 * @Date: 2025/10/20 18:59
 *
 **/
@Data
@AllArgsConstructor
public class User {
    /**
     * 用户ID主键
     */
    private Long id;
    /**
     * 用户名称
     */
    private String name;
}

编写Controller

/**
 * 用户管理接口
 * @Author: micro麦可乐
 * @Date: 2025/10/20 18:59
 */
@RestController
@RequestMapping("/users")
public class UserController {

    /**
     * 获取用户列表
     * @return 返回用户列表
     */
    @GetMapping
    public List<User> list() {
        List<User> list = new ArrayList<>();
        list.add(new User(1L, "Alice"));
        list.add(new User(2L, "Bob"));
        return list;
    }

    /**
     * 创建用户
     * @param user
     * @return 返回创建用户
     */
    @PostMapping
    public User create(@RequestBody User user) {
        user.setId(3L);
        return user;
    }

    /**
     * 根据ID获取用户信息
     * @param id 用户ID
     * @return 返回用户对象
     */
    @GetMapping("/{id}")
    public User getUserById(@PathVariable Long id) {
        return new User(id, "张三");
    }
}

运行生成文档

生成文档命令

mvn smart-doc:html

通过IDEA maven生成

文档最终生成效果

结语

通过本文的讲解以及快速集成案例,相信小伙伴们已经掌握了在 SpringBoot 项目中整合smart-doc的方法。smart-doc 的零侵入特性让我们的代码更加整洁,基于注释的文档生成方式也更符合开发者的习惯。赶紧在项目中尝试使用smart-doc,体验它带来的便捷和高效吧!

以上就是SpringBoot项目集成Smart-Doc的实战指南的详细内容,更多关于SpringBoot集成Smart-Doc的资料请关注脚本之家其它相关文章!

相关文章

  • @annotation AOP编程的pointcut定义方式

    @annotation AOP编程的pointcut定义方式

    文章介绍通过注解简化AOP复杂结构定义,避免繁琐的逻辑组合,提升开发效率,并展示IDE如何辅助查看切入点匹配
    2025-08-08
  • SpringBoot中事务的只读属性详解

    SpringBoot中事务的只读属性详解

    这篇文章主要介绍了SpringBoot中事务的只读属性详解,在开发过程中,事务是一个非常重要的概念,在 Spring Boot中,事务是通过 AOP 机制来实现的,可以很方便地进行管理,需要的朋友可以参考下
    2023-08-08
  • spring boot 防止重复提交实现方法详解

    spring boot 防止重复提交实现方法详解

    这篇文章主要介绍了spring boot 防止重复提交实现方法,结合实例形式详细分析了spring boot 防止重复提交具体配置、实现方法及操作注意事项,需要的朋友可以参考下
    2019-11-11
  • 一文搞懂hashCode()和equals()方法的原理

    一文搞懂hashCode()和equals()方法的原理

    这篇文章主要介绍了详解hashCode()和equals()的本质区别和联系,本文先对两种方法作了介绍,然后对二者联系进行分析,具有一定参考价值,需要的朋友可以了解下
    2020-06-06
  • 解决Java中由于数据太大自动转换成科学计数法的问题

    解决Java中由于数据太大自动转换成科学计数法的问题

    今天小编就为大家分享一篇解决Java中由于数据太大自动转换成科学计数法的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • SpringBoot中自定义参数绑定步骤详解

    SpringBoot中自定义参数绑定步骤详解

    这篇文章主要介绍了SpringBoot中自定义参数绑定步骤详解,非常不错,具有参考借鉴价值 ,需要的朋友可以参考下
    2018-02-02
  • MyBatis高级映射ResultMap解决属性问题

    MyBatis高级映射ResultMap解决属性问题

    对于数据库中对表的增删改查操作,我们知道增删改都涉及的是单表,而只有查询操作既可以设计到单表操作又可以涉及到多表操作,所以对于输入映射parameterType而言是没有所谓的高级映射的,也就是说高级映射只针对于输出映射
    2023-02-02
  • 浅谈Java利用表格模型创建表格

    浅谈Java利用表格模型创建表格

    这篇文章主要介绍了Java利用表格模型创建表格,需要的朋友可以参考下
    2017-09-09
  • springboot+shiro+jwtsession和token进行身份验证和授权

    springboot+shiro+jwtsession和token进行身份验证和授权

    最近和别的软件集成项目,需要提供给别人接口来进行数据传输,发现给他token后并不能访问我的接口,拿postman试了下还真是不行,检查代码发现项目的shiro配置是通过session会话来校验信息的,修改代码兼容token和session
    2024-06-06
  • Java Javassist轻松操作字节码的技术指南

    Java Javassist轻松操作字节码的技术指南

    Javassist 是一个 Java 库,允许你在运行时定义新类或修改现有类文件,本文主要为大家详细介绍了如何使用Javassist轻松操作字节码,感兴趣的小伙伴可以参考一下
    2025-04-04

最新评论