Dockit
 
   😭 
   
   😭 
   别光fork啊,麻烦点个star
   😭 
  
 
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
-  请求参数也可以嵌套对象了 
-  增加请求参数示例 
 JarCasting
 JarCasting