美文网首页
一个极简的Java RESTful API文档工具smalldo

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

作者: 蜀黍凯 | 来源:发表于2019-10-16 18:58 被阅读0次

    项目

    为什么要造轮子?

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

    特性

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

    实现方式

    使用

    示例为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;
        }
    }
    
    接口文档
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    文档API(用来实现自定义UI)
    • URL: http://192.168.1.76:8080/my-project/smalldoc/
    • METHOD: POST
      在这里插入图片描述

    注意

    • source-paths 配置项表示额外的源码路径,项目的源码路径默认已经包含在内,不需要额外添加,只需要指定扫描的包,比如:my.project.controller
    • 程序只会解析类名为*Controller的源代码中的接口信息(规范)
    • 程序暂未支持Linux环境,在项目打包部署之前,记得关闭文档功能,关闭方式多种多样,比如:
      1. spring.profiles.active=*(* 只要不是dev即可),不再激活开发环境配置
      2. smalldoc.enabled=false,关闭启用
      3. 修改依赖作用域为test后再进行打包,这样连smalldoc的jar包都不会被打包进去(推荐)
         <dependency>
               <groupId>com.github.liuhuagui</groupId>
               <artifactId>smalldoc-spring-boot-starter</artifactId>
               <version>2.2</version>
               <scope>test</scope>
         </dependency>
        

    社区

    如果在使用过程中需要帮助或者希望项目增加某些功能,欢迎issue —— https://github.com/liuhuagui/smalldoc/issues

    相关文章

      网友评论

          本文标题:一个极简的Java RESTful API文档工具smalldo

          本文链接:https://www.haomeiwen.com/subject/yvgumctx.html