logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

Smart-Doc

Smart-Doc是一款强大的基于Java的API文档生成工具。它通过对接口源代码进行分析来生成全面而准确的文档,完全不需要对代码进行任何注入。这种非侵入式的方法确保了无需添加特殊注解或修改代码即可生成文档,使得集成变得无缝且简单

官方文档

文档地址

Maven安装

加上Maven插件即可,不用其他依赖

<plugin>
    <groupId>com.github.shalousun</groupId>
    <artifactId>smart-doc-maven-plugin</artifactId>
    <version>2.2.8</version>
    <configuration>
        <!--指定smart-doc使用的配置文件路径-->
        <configFile>./src/main/resources/smart-doc.json</configFile>
        <!--指定项目名称-->
        <projectName>fan-blog-doc</projectName>
    </configuration>    
    <executions>
        <execution>
            <goals>
                <!--smart-doc提供了html、openapi、markdown等goal,可按需配置-->
                <goal>openapi</goal>
            </goals>
        </execution>
    </executions>
</plugin>

然后就可以在项目中使用改插件生成文档

配置

根据配置的文件路径创建JSON文件,示例

{
  "serverUrl": "http://localhost:8000", //指定后端服务访问地址
  "outPath": "src/main/resources/static/doc", //指定文档的输出路径,生成到项目静态文件目录下,随项目启动可以查看
  "isStrict": false, //是否开启严格模式
  "allInOne": true, //是否将文档合并到一个文件中
  "createDebugPage": true, //是否创建可以测试的html页面
  "style": "xt256", //基于highlight.js的代码高设置
  "projectName": "接口文档测试", //配置自己的项目名称
  "showAuthor": true, //是否显示接口作者名称
  "allInOneDocFileName": "index.html" //自定义设置输出文档名称
}

更多详细配置看文档的Maven模块下

推送到Torna

Torna官网,详情见开发文档

在配置文件中指定相关数据即可

{
  "serverUrl": "http://localhost:8000", //指定后端服务访问地址
  "outPath": "src/main/resources/static/doc", //指定文档的输出路径,生成到项目静态文件目录下,随项目启动可以查看
  "isStrict": false, //是否开启严格模式
  "allInOne": true, //是否将文档合并到一个文件中
  "createDebugPage": true, //是否创建可以测试的html页面
  "style": "xt256", //基于highlight.js的代码高设置
  "projectName": "接口文档测试", //配置自己的项目名称
  "showAuthor": true, //是否显示接口作者名称
  "allInOneDocFileName": "index.html", //自定义设置输出文档名称
  "packageFilters": "",//controller包过滤,多个包用英文逗号隔开
  "appKey": "20211104905771723889049600",// torna平台对接appKey,, @since 2.0.9
  "appToken": "f347ea5e57c640ac88f63486479e029b", //torna平台appToken,@since 2.0.9
  "secret": "nEpwXU##mBgwdra*BN6r,1TVxjv@5a8#",//torna平台secret,@since 2.0.9
  "openUrl": "http://localhost:7700/api",//torna平台地址,填写自己的私有化部署地址@since 2.0.9
  "debugEnvName":"测试环境", //torna测试环境
  "debugEnvUrl":"http://localhost:8000" //torna
}

注释使用

在类上加注释

/**
 * 测试接口
 *
 * @author FanJun
 * @author Wang
 */

在接口上加注释

 /**  
   * 接口标题
   *
   * @param req 参数
   * @return 返沪统一响应对象
   * @apiNote 接口描述
   */

注意:在方法上加了作者后,该接口的作者只有方法上的,类上的作者名不再显示

删除接口

不想删除代码的方式

请求方式

主要取决与接口是否使用了@RequestBody注解,如果使用了就是application/json; charset=utf-8,否则application/x-www-form-urlencoded;charset=utf-8

使用总结

接口作者

统一类方式:该类下没有使用@author的接口都会使用类上的作者

/**
 * 分类相关接口
 *
 * @author Fan
 */
@RestController
public class CategoryController {
}

单个接口指定方式:在文档中只会出现指定的名字,统一的指定不会出现

/**
 * 获取分类列表(管理)
 *
 * @author Zhang
 */
@PostMapping("/manage/category/list")
public Result<List<Category>> list() {
}

多作者指定方式:

/**
 * 获取分类列表(管理)
 *
 * @author Fan
 * @author Zhang
 */
@PostMapping("/manage/category/list")
public Result<List<Category>> list() {
}

接口废弃

在文档上用线划掉,表示废弃

/**
 * 获取分类列表(管理)
 *
 * @deprecated
 */
@Deprecated
@PostMapping("/manage/category/list")
public Result<List<Category>> list() {
}

接口删除

不会在文档上出现

/**
 * 获取分类列表(管理)
 *
 * @ignore
 */
@PostMapping("/manage/category/list")
public Result<List<Category>> list() {
}

接口详细描述

/**
 * 获取分类列表(管理)
 * 
 * @apiNote 这里是对该接口的详细说明
 */
@PostMapping("/manage/category/list")
public Result<List<Category>> list() {
}

分组方式

官方弃用@tag,使用配置的方式,支持正则

"groups": [
  {
    "name": "管理相关接口",
    "apis": "com.fan.controller.manage.*"
  }
]
Smart-Doc
官方文档
Maven安装
配置
推送到Torna
注释使用
删除接口
请求方式
使用总结
接口作者
接口废弃
接口删除
接口详细描述
分组方式