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

相关推荐
带刺的坐椅1 小时前
FastJson2 与 SnackJson4 有什么区别?
java·jsonpath·fastjon2·snack4
linweidong1 小时前
C++如何避免 ODR(One Definition Rule)冲突?
java·jvm·c++
毅炼2 小时前
hot100打卡——day09
java·leetcode
没有bug.的程序员2 小时前
HashMap 源码深度剖析:红黑树转换机制与高并发性能陷阱
java·性能优化·并发编程·源码分析·红黑树·hashmap·技术深度
yaoxin5211232 小时前
294. Java Stream API - 对流进行归约
java·开发语言
曹轲恒2 小时前
Thread.sleep() 方法详解
java·开发语言
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-考试模块前端页面交互设计及优化
java·数据库·人工智能·spring boot
小小仙。2 小时前
IT自学第十九天
java·开发语言
悟空码字2 小时前
SpringBoot集成Hera,分布式应用监控与追踪解决方案
java·springboot·编程技术·后端开发·hera