Maven插件apiscan介绍与使用

这是我自己写的一个小工具的README内容

项目背景

程序员最讨厌的两件事:一是别人的代码没有文档,二是给自己的代码写文档。

有买卖就有伤害有需求就有市场,比如swagger就可以自动生成文档,但是swagger是侵入式的,需要程序员手动编写代码,且与业务代码混在一起。

本项目是一个maven插件,只要在pom.xml中集成本插件,就可以自动生成markdown格式的API文档。

与此功能类似的有一个apiggs,apiggs通过解析源文件生成接口文档,所以可以读取注释,但最新一次更新也已经是2019年了,对Spring的支持也不完善。

本项目通过ClassLoader获取类信息,所以获取不了字段注释,但是对Spring的支持比apiggs更完善。

功能说明

本项目运行时的类信息,生成Spring项目的Http接口文档的Maven插件。

注:下文中插件项目 指本仓库代码,业务项目指使用本插件的项目。

快速使用

1. 编译本插件项目的代码,并安装到本地Maven仓库

shell 复制代码
mvn clean install

2. 在业务项目的pom.xml引入插件

xml 复制代码
<build>
    <plugins>
        <plugin>
            <groupId>com.github.apiscan</groupId>
            <artifactId>apiscan-spring-maven-plugin</artifactId>
            <version>0.0.1</version>
            <executions>
                <execution>
                    <goals>
                        <goal>scan</goal>
                    </goals>
                </execution>
            </executions>
            <!--configuration的配置可选。不写configuration配置的情况下,默认值:output=API,debug=false-->
            <configuration>
                <!--文档输出目录(相对于pom.xml所在的目录)-->
                <output>API文档</output>
                <!--是否打开debug模式-->
                <debug>true</debug>
            </configuration>
        </plugin>
    </plugins>
</build>

3. 编译业务项目即可生成API文档

shell 复制代码
mvn clean compile

调试本插件项目代码

  1. 在业务项目进行调试编译
shell 复制代码
mvnDebug clean compile

执行命令后,进入debug模式,等待调试程序运行,debug默认端口是8000。

  1. 在插件项目中运行Remote JVM Debug

点击IDEA右上角Run按钮左边的Run / Debug Configurations,在下拉列表选择Edit Configurations...,点击弹出窗口左上角的+按钮,选择Remote JVM Debug,在ConfigurationPort填入第一步显示的debug端口8000,最后运行该运行配置即可进入插件Debug模式。

欢迎加入

本项目在github与gitcode都有代码仓,欢迎加入,一起完善插件功能。

github: https://github.com/ncuht/apiscan

gitcode: https://gitcode.com/java_t_t/apiscan/tree/master

联系我

由于不常登陆github和gitcode,若响应不及时,请直接发送邮件到我邮箱 hetao_ncu@foxmail.com

相关推荐
手握风云-6 小时前
Spring AI:让大模型住进 Spring 生态(三)
java·后端·spring
咸鱼2.07 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
JAVA面经实录91713 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
许彰午15 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
Bat U16 小时前
JavaEE|多线程初阶(七)
java·开发语言
掌心向暖RPA自动化18 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭18 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
TeamDev19 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手20 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试