好用的文档工具👉smart-doc
好用的文档工具smart-doc
smart-doc不得不说是一款非常好用的文档工具,尤其是它几乎不与项目耦合的特性十分值得所有java开发人员日常使用它~
之前及现在用的
我从事开发以来,用过形形色色各式各样的文档工具,比如一开始的用
01. word或excel

这种文档十分依赖于开发人员同步维护,另外office与代码是两套东西,耗时耗力且很容易
由于疏忽忘记维护,导致版本版本不一致的问题~
02. showdoc

这东西看起来比较美观,非常适合外部人员接入之使用,当然缺点也很明显:
- 公开文档安全及私密性就差很多
- 也同样存在手动编写的问题,需要跟随代码同步维护
- 使用范围比较窄,虽方便接入人员用,测试及开发自测仍旧比较麻烦
- 导入导出似乎受限制,不知道现在有没改善
03. swagger

后来有了有了 swagger,一开始觉得这东西蛮不错的,主要体现在:
- 不需要再写word或excel
- 定义文档接口的方式更贴合传统编码的方式
- 文档可生成在线网页doc的方式也可以通过跑代码生成
adoc文件+asciidoctor工具生成单html文档,这非常利于文档分发
东西虽好,但是缺点也是十分明显的:
- 代码耦合性太强了,
swagger依赖必须与代码一起部署(包括生产) - 在线文档十分便捷,但是由于
swagger可能的漏洞的存在,增加了系统风险的可能性(这个本人碰到过) - 能生成实用的``html文档,可似乎缺少了供测试使用的
jmeter及postman文档,测试人员依然需要手动构建测试接口 - 特别需要注意的是
swaggerv2及之后似乎缺少了html文档的生成途径(文档工具不能越做越返祖啊...) swagger文档不论是在线的还是离线的文档 对于复杂的json需要逐级便利 (如果能平铺为一个table就好了)
04. smart-doc

这个文档工具在目前我所经手的项目中广泛之使用,如图,需要的功能基本都有了
smart-doc 有啥优点
- 由于仅有
plugin及一个json配置,无任何ApiModelProperty、ApiModel及Schema侵入性注解代码 - 可以生成诸如
html(单文件需要先走adoc后转html)、openapi、postman、jmeter、word等主流且前端用也可后端测试用之文档 - 文档定义更简单,仅需有限的注解及
Jakarta相关注解配合使用即可, 其他扩展文档见 smart-doc
如何使用
- 在项目中添加
plugin配置,这里仅以maven项目实例
<!--文档工具-->
<plugin>
<groupId>com.ly.smart-doc</groupId>
<artifactId>smart-doc-maven-plugin</artifactId>
<version>3.1.0</version>
<configuration>
<!--配置文件位置-->
<configFile>./src/main/resources/smart-doc.json</configFile>
<!--<projectName>${application.name}</projectName>-->
<!--<configFile>${application.name}</configFile>-->
</configuration>
<!--项目编译时执行生成html不需要可以去掉executions标签-->
<executions>
<execution>
<!--打包的时候构建文档(install package)-->
<phase>package</phase>
<goals>
<!--adoc文档,后续用asciidoc生成html单文档-->
<goal>adoc</goal>
<!--构建文档类型 -->
<!--api只构建html文档-->
<!--<goal>html</goal>-->
<!--统一接口只构建adoc文档-->
<!--<goal>rpc-adoc</goal>-->
</goals>
</execution>
</executions>
</plugin>
<!--文档工具:用于将smart-doc生成的adoc文件转换为html文档-->
<plugin>
<groupId>org.asciidoctor</groupId>
<artifactId>asciidoctor-maven-plugin</artifactId>
<version>1.5.8</version>
<configuration>
<!--预构建文档目录-->
<sourceDirectory>./adoc</sourceDirectory>
<!--文档输出目录-->
<outputDirectory>./doc</outputDirectory>
<headerFooter>true</headerFooter>
<doctype>book</doctype>
<backend>html</backend>
<sourceHighlighter>coderay</sourceHighlighter>
<attributes>
<!--菜单栏在左边-->
<toc>left</toc>
<!--多标题排列-->
<toclevels>3</toclevels>
<!--自动打数字序号-->
<sectnums>true</sectnums>
</attributes>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>process-asciidoc</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- 文档工具结束-->
plugin在多模块项目中表现为:

- 在项目中定义
smart-doc.json配置文件,一般在resources目录下
{
"outPath":"adoc",
"allInOne":true,
"allInOneDocFileName":"mee_admin-1.0.1",
"projectName":"mee_admin",
"createDebugPage":true,
"revisionLogs":[
{
"version":"2025-06-26",
"author":"shadow",
"revisionTime":"2025-06-26 19:28:18",
"status":"1.0.1",
"remarks":"接口及文档优化"
}
]
}
这个 smart-doc.json 在 plugin 中有引用,相对地址不要弄错了

- 在
idea的maven面板依次操作=>生成单html文档文件

使用技巧及注意事项
- 字段的注释不可以含有竖杠(eg:
|), 可能造成文档出现偏移
// eg:
/**
* 菜单类型(1.目录 | 2.菜单 | 3.按钮)
*/
private Integer type;
- 入口注释字段
@param的值不可为空, 可导致无法生成文档
// eg:
/**
* 系统::文件管理::删除
* @param status 状态
* @param
*/
@RequiresPermissions("sys:sys_file:delete")
@DeleteMapping("/delete")
@ResponseBody
public MeeResult<Integer> deleteById(@RequestParam(required = true) String id,@RequestParam(required = true) String status){
return sysFileService.deleteById(id,status);
}
smart-doc强烈推荐使用3.1.x以上的版本,若使用3.1.x以下版本 多个@RequestHeader时生成的文档会出现行偏移
// eg:
@RequiresPermissions("sys:sys_file:delete")
@DeleteMapping("/delete")
@ResponseBody
public MeeResult<Integer> deleteById(@RequestHeader String aa ,@RequestHeader String status){
return sysFileService.deleteById(id,status);
}
- 一定要注意
xml配置的目录或文件的位置


生成的
jmeter文档不可避免的会出现打不开的问题,一般来是注释含有
或者 数字或布尔默认值问题,此类问题建议按提示的行数 修改jmx内对应的行即可具体配置参见smart-doc官方文档
文档生成效果
- 单
html文档

jmeter文档

word文档

好用的文档工具👉smart-doc的更多相关文章
- Javascript自动化文档工具JSDuck在Windows下的使用心得
作者: zyl910 一.工具比较 为了让前端JavaScript程序更具可维护性,更利于团队开发,文档非常重要.此时便需要使用自动化文档工具了. 我对比了各种JavaScript自动化文档工具,发现 ...
- 如何写Java文档注释(Java Doc Comments)
本文翻译自How to Write Doc Comments for the Javadoc Tool,但是精简了一些私以为不重要的东西 本文不讨论如何使用javadoc工具自动生成文档的方法,而是主 ...
- 生成chm文档工具- Sandcastle -摘自网络
Sandcastle是微软官方的文档生成工具,NDoc开发停止后,这个貌似也是唯一的一个这方面的工具.它从dll文件及其xml注释文件能够 生成完整的帮助文档,支持多种生成格式(Helpe1x:chm ...
- API文档工具-Swagger的集成
最近安装了API文档工具swagger,因为Github上已有详细安装教程,且安装过程中没有碰到大的阻碍,所以此文仅对这次安装做一份大致记录 相关网站 Swagger 官方地址: http://swa ...
- Spring Boot (十五): 优雅的使用 API 文档工具 Swagger2
1. 引言 各位在开发的过程中肯定遇到过被接口文档折磨的经历,由于 RESTful 接口的轻量化以及低耦合性,我们在修改接口后文档更新不及时,导致接口的调用方(无论是前端还是后端)经常抱怨接口与文档不 ...
- JavaScript(3)——文档工具
文档工具 LEARN HTML = 教程 HTML REFERENCE = 字典 HTML + CSS + JAVASCRIPT = DYNAMIC HTML 推荐浏览器: Chrome浏览器(有丰 ...
- ShowDoc,APIDoc,可道云API,语雀-适合IT企业的文档工具
ShowDoc,APIDoc,可道云API,语雀-适合IT企业的文档工具 一.ShowDoc官方文档及说明 1.1 它可以用来做什么 1.2 它都有些什么功能 1.3 使用在线的ShowDoc 1.4 ...
- 开源API文档工具- swagger2 与 smart-doc 比较 与 使用
工具开源地址 swagger2 : https://swagger.io/ smart-doc: https://www.oschina.net/p/smart-doc 国产 两者的比较 swagg ...
- 【Lua】LDoc生成Lua文档工具的使用
参考资料: http://my.oschina.net/wangxuanyihaha/blog/188909 LDoc介绍: LDoc是一个Lua的文档生成工具,过去,比较常用的Lua生成 ...
- Java非侵入式API接口即文档工具apigcc
一个非侵入的api编译.收集.Rest文档生成工具.工具通过分析代码和注释,获取文档信息,生成RestDoc文档 前言 程序员一直以来都有一个烦恼,只想写代码,不想写文档.代码就表达了我的思想和灵魂. ...
随机推荐
- Object类--toString方法--java进阶day05
1.Object类.以及通用的类 2.toString方法 默认的toString方法,返回的是地址值(全类名再加上通过地址值算出来的十六进制哈希值) . 为什么打印语句会自动调用toString方法 ...
- DeepSeek 聊天机器人项目
想要更深入玩转聊天机器人开发? 推荐本文档 + 课程<DeepSeek 聊天机器人项目>一起学习,效果翻倍! 边学边练,轻松打造智能对话系统~ (๑•̀ㅂ•́)و✧ 快上车,AI 之旅发车 ...
- DevOps与:cloud,IaC,Container,Microservices, Serverless
本文我们来理一理当下最火的技术与DevOps的关系,2020年可以考虑从如下的几方面来改进DevOps. DevOps代表开发和运营.它的目标是将开发.质量保证和运营(部署和集成)合并到一个单一的.连 ...
- idea远程访问docker查看控制台中文乱码问题
今天心血来潮想把自己的项目部署到docker,部署完成后通过idea远程访问docker.发现控制台日志出现中文乱码,起初还以为docker或者项目编码没有设置好,一一排查后发现服务器编码和环境都没有 ...
- Lua 的os.date()
Lua os.date() os.date## 原型:os.date ([format [, time]]) 解释:返回一个按format格式化日期.时间的字串或表. usage## 参数格式: 由原 ...
- WPF旋转板栈设计一例
效果图 项目中需要做一个机台的平面视图,点击其中一个料盒时,弹出该料盒的料管列表,用WPF示例做了一下,效果如下: 用户控件XAML 1 <UserControl x:Class="W ...
- CSS定位的写法
如上图,商品添加完成后,需要验证商品是否添加成功,通过验证商品列表内是否存在指定名称的商品即可实现验证 浏览器自动获取的xpath=//*[@id="ProductName-divrid53 ...
- Python 潮流周刊#98:t-string 语法被正式接纳了(摘要)
本周刊由 Python猫 出品,精心筛选国内外的 250+ 信息源,为你挑选最值得分享的文章.教程.开源项目.软件工具.播客和视频.热门话题等内容.愿景:帮助所有读者精进 Python 技术,并增长职 ...
- Linux各种服务配置开机自启
一.Linux配置redis开机自启 (1)到redis配置文件中找到conf文件:vi redis.conf (2)daemonize no 修改为:daemonize yes (3)cd /etc ...
- Windows上,10分钟构建一个本地知识库
这篇文章是我约新书<RAG应用实战>的一个样章,基于阿里云代码构建的一个本地RAG服务. 本地模型看代码注释,需要替换几行代码. 阅读本章时,已默认安装你的个人电脑上安装了Python 3 ...