转载

一个极简的Java RESTful API文档工具smalldoc

  • github.com/liuhuagui/s… 一个基于Java标准注释的 RESTful API 文档工具
  • smalldoc-antd-react-ui ( github.com/liuhuagui/s…

为什么要造轮子?

  • 强迫症患者,接受不了 Swagger 的各式注解对代码的入侵造成的冗杂,更渴望清洁的代码;
  • 注解的使用需要一定的学习成本;
  • 随后尝试使用 Apidoc ,尽管Apidoc是基于注释生成文档,但是学习成本并没有降低,你需要学习额外的注释 Tag ,同时你不得不使用这些特殊的 Tag 将你所需接口的相关信息手动写出来,感觉并没有大幅度降低书写文档的工作量;
  • 也有一些基于Java标准注释生成文档的项目,但是有的无法支持实体参数、泛型变量、多模块依赖,有的Bug太多,UI界面不够友好,使用方式过于复杂,甚至逻辑处理上存在问题。

特性

  • 基于Java源码、标准注释以及Tag生成文档,无代码入侵,保证代码整洁,同时保证开发人员的注释习惯与注释规范
  • 提供了友好的默认UI
  • 提供了文档RESTEful API,支持实现自定义UI
  • 提供规范配置方式,使用更方便
  • 提供相应的spring-boot-starter,同时支持传统spring与spring-boot
  • 支持关联实体参数
  • 支持泛型
  • 支持忽略某个参数
  • 支持忽略解析指定包或指定类型参数的数据结构
  • 支持多模块项目(从指定Jar包中解析源码或数据结构)

实现方式

  • 解析源码文件,通过源码及其中的注释生成文档信息。目前为止注释中使用的Tag都是Java注释的标准Tag,后续可能会添加一些必要的自定义Tag,甚至有可能提供Tag扩展机制 —— 由使用者自定义Tag,同时自定义Tag的处理方式。

  • 一想到生成Java RESTful API文档,首先就是想到Java API文档是如何生成的,所以解析源码的方式没有选择使用 com.github.javaparser » javaparser-core 或者 com.thoughtworks.qdox » qdox ,而是选择JDK自己的 Javadoc Tool ( docs.oracle.com/en/java/jav… Tool对应的API是 Javadoc API ( docs.oracle.com/en/java/jav…

  • 由于作者还在使用 Java8 ,所以该项目的实现完全是基于 Javadoc API 旧版

    • Package com.sun.tools.javadoc ( docs.oracle.com/en/java/jav… )
    • Package com.sun.javadoc ( docs.oracle.com/en/java/jav… )

    其中:

    Modulejdk.javadoc Package com.sun.tools.javadoc This package and its contents are deprecated and may be removed in a future release. See javax.tools. ToolProvider.getSystemDocumentationTool and javax.tools.DocumentationTool for replacement functionality.

    Modulejdk.javadoc Package com.sun.javadoc Note: The declarations in this package have been superseded by those in the package jdk.javadoc.doclet . For more information, see the Migration Guide in the documentation for that package.

    @Deprecated(since="9",forRemoval=true)
    public class Main extends Object
    复制代码

    可以看出,旧版Javadoc API自 Java9 已经被标记遗弃,在不久的将来将被移除,但是值得庆幸,直到最新的大版本 Java12 该API还未移除,所以使用 Java12 及以前版本的用户可以放心使用,后续作者会提供新版API支持。

  • UI界面是基于 create-react-appantd 开发的single page application —— smalldoc-antd-react-ui ( github.com/liuhuagui/s…

使用

示例为spring-boot项目,使用 application.yml 做为配置文件

引入依赖

<dependency>
    <groupId>com.github.liuhuagui</groupId>
    <artifactId>smalldoc-spring-boot-starter</artifactId>
    <version>2.3</version>
</dependency>
复制代码

配置

接口文档通常在开发时使用,只需要保证文档配置在开发环境下生效 —— spring.profiles.active=dev

server: 
  port: 8080
  servlet:
    context-path: /my-project
spring: 
  profiles:
    active: dev
---
spring:
  profiles: dev
smalldoc:
  source-paths: #额外的源码路径(项目的源码路径默认已经包含在内,不需要再添加)
    - 'D:/Workspaces/myBeanProject/my-bean/src/main/java'
    - 'D:/Maven/Repositories/repository/com/aliyun/aliyun-java-sdk-core/3.5.0'
  packages:
    - quantity.knowledgebase
    - my.bean
    - com.aliyuncs.auth.sts
  project-name: 我的文档
  enabled: true #默认为true
  url-pattern: /smalldoc/* #默认为/smalldoc/*
复制代码

访问地址

  • URL: http://192.168.1.76:8080/my-project/smalldoc/
  • METHOD: GET

接口源码

/**
 * 文章的创建,编辑,发布,自定义
 * @author KaiKang 799600902@qq.com
 */
@RestController
@RequestMapping("w")
public class WriteArticleController {
    /**
     * 原创文章在编辑中保存
     * @param content 内容
     * @param oaCopy  原创文章副本
     * @return data-草稿ID
     * @author KaiKang 799600902@qq.com
     */
    @PostMapping(path = "o/save_draft",produces = {"text/plain", "application/json;charset=UTF-8"},consumes = "application/x-www-form-urlencoded")
    public Result<Long> saveOriginalDraft(String content, OriginalArticleCopy oaCopy, HttpServletRequest request) {
        return writeArticleService.saveOriginalDraft(content, oaCopy);
    }

    /**
     * 这只是一个测试接口
     * @param content 内容
     * @return 返回数据
     * @author KaiKang 799600902@qq.com
     */
    @GetMapping(path = "o/save",produces = {"text/plain", "application/json;charset=UTF-8"})
    public Result<OriginalArticle> save(String content, HttpServletRequest request) {
        return null;
    }
}
复制代码

接口文档

一个极简的Java RESTful API文档工具smalldoc
一个极简的Java RESTful API文档工具smalldoc
一个极简的Java RESTful API文档工具smalldoc

文档API(用来实现自定义UI)

  • URL: http://192.168.1.76:8080/my-project/smalldoc/
  • METHOD: POST
    一个极简的Java RESTful API文档工具smalldoc
原文  https://juejin.im/post/5da701a9e51d4524d55484ce
正文到此结束
Loading...