Dockit
Dockit 是一个通过javadoc生成markdown文档的生成工具。
-
不依赖于@RequestMapping注解,直接根据javadoc中是否有@title来生成接口文档
-
可应用于dubbo项目中
-
若需要dockit生成文档,则需要在类的javadoc中加入@dockit 如:
/**
* @author ysdxz207
* @date 2018-08-02
* @dockit 阿福接口
*/
- 生成dockit目录结构如下:
dockit - 阿福接口 - 阿福列表接口.MD
- 若不需要按目录生成,则可以设置插件参数singleOutDir=true
- pom.xml:
<plugin>
<groupId>com.hupubao</groupId>
<artifactId>dockit-maven-plugin</artifactId>
<version>2.1.4.RELEASE</version>
<configuration>
<templateCharset>UTF-8</templateCharset>
<singleOutDir>false</singleOutDir>
<outDir>${project.build.directory}/dockit</outDir>
<!-- 自动打开生成的文档目录,默认false -->
<autoOpenOutDir>true</autoOpenOutDir>
<!-- 这里可以选择自定义模版 -->
<!--<template>${basedir}/src/main/resources/dockit/TEMPLATE.MD</template>-->
</configuration>
<!--
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>dockit</goal>
</goals>
</execution>
</executions>
-->
</plugin>
-
mvn clean dockit:dockit
-
你也可以根据默认模版 DEFAULT.MD 自定义你的文档模版,将插件template参数修改为你的模板路径即可
-
javadoc 格式如下:
/**
* @title 阿福列表接口
* @desc 获取阿福列表
* @url afu.list
* @version 1.0.0
* @status 可用
* @method POST
* @arg pageNum,Integer,是,页码
* @arg pageSize,Integer,否,分页大小
* @arg obj, Object, 否, 参数
* @arg obj.name, String, 否, 名称
* @arg obj.createTime, String, 否, 创建事件
* @resArg service,Object,是,请求服务,原样返回
* @resArg service.subObject,Object,是,service子对象
* @resArg service.subObject.id,Integer,是,service子对象ID
* @resArg service.subObject.name,String,是,service子对象名
* @resArg service.subArray,Array,是,service子数组
* @resArg service.subArray.name,String,是,service子数组名
* @resArg list,Array,是,阿福列表
* @resArg list.id,String,是,ID
* @resArg list.name,String,是,名称
* @resArg list.type,String,是,类型
* @resArg list.createTime,String,是,创建时间
* @resArg list.content,String,是,内容
* @resArg list.arr,Array,是,数组
* @resArg list.arr.arrName,String,是,数组名
* @resArg list.arr.arrValue,String,是,数组值
* @resArg list.arr.subArr,Array,是,子数组
* @resArg list.arr.subArr.subArrId,String,是,子数组ID
* @resArg list.arr.subArr.subArrName,String,是,子数组名
* @resArg list.arr.subObj,Object,是,子对象
* @resArg list.arr.subObj.objId,String,是,子对象ID
* @resArg list.arr.subObj.objName,String,是,子对象名
*
*/
-
生成样例
-
标签释义
标签名 | 释义 | 格式 |
---|---|---|
@title |
接口名,若需要此接口生成文档,则此标签必选 | - |
@arg |
请求参数 | 参数名,类型,是否必填,参数描述 |
@resArg |
返回参数 | 参数名[.属性],类型(除其他类型外还可以是Object或Array),是否必填,参数描述 |
历史更新
- 2.1.4.RELEASE
- 增加了参数:autoOpenOutDir,当环境支持的时候,会自动打开生成的文档所在的目录。
- 增加了未配置
@dockit
时的日志输出。
- 2.1.3.RELEASE
- 2019-08-29因更换域名,更换了插件的groupId从win.hupubao改为com.hupubao
- 2.1.1.RELEASE
- 解决字段描述中出现英文逗号则会丢失逗号后部分内容问题
- 2.1.0.RELEASE
-
请求参数也可以嵌套对象了
-
增加请求参数示例