Swaggo/Swag:Go语言RESTful API文档自动生成工具
2026-01-16 10:18:51作者:薛曦旖Francesca
1. 项目介绍
Swaggo/Swag 是一个用于Go语言的应用程序,它能够帮助开发者自动地生成符合Swagger 2.0规范的API文档。通过在代码中添加注释,Swag可以解析这些注释并创建易于理解的RESTful API文档,使得客户端开发者更容易理解和使用你的接口。
2. 项目快速启动
安装Swag
首先,确保已经安装了Go环境,然后可以通过go get命令安装Swag:
go get -u github.com/swaggo/swag/cmd/swag
示例项目初始化
在一个新的Go项目中,你可以运行以下命令来初始化Swag:
swag init
这将在项目根目录下生成两个文件:docs 和 docs/api.json。docs/api.json 文件包含了你的API文档信息,而docs 目录将被用作Swagger UI的入口点。
添加注释和运行
在你的代码中,例如一个处理函数上,添加如下注释:
// @Summary List accounts
// @Description get accounts
// @Tags accounts
// @Accept json
// @Produce json
// @Success 200 {array} models.Account
// @Router /accounts [get]
func ListAccounts(c *gin.Context) {
...
}
运行你的应用,然后访问http://localhost:8080/swagger/index.html(根据你的服务配置)查看生成的Swagger UI界面。
3. 应用案例和最佳实践
Swag 可以很好地集成到Gin框架中,提供详细的API说明。例如,定义自定义类型并使用swaggertype标签支持非标准数据类型:
// CerticateKeyPair 自定义证书密钥对
type CerticateKeyPair struct {
Crt []byte `json:"crt" swaggertype:"string" format:"base64" example:"U3dhZ2dlciByb2Nrcw=="` // base64编码的证书
Key []byte `json:"key" swaggertype:"string" format:"base64" example:"U3dhZ2dlciByb2Nrcw=="` // base64编码的私钥
}
在定义完结构体后,Swag可以根据注释和提供的示例生成相应的文档。
4. 典型生态项目
Swag 已经被广泛应用于许多Go语言的Web开发项目中,包括但不限于:
- Gin:一个流行的轻量级Go web框架,与Swag集成良好。
- Beego:另一个常见的Go web框架,也支持Swag进行API文档自动化。
- Echo:基于Go语言的高性能web框架,通过插件也可以集成Swag。
以上就是Swaggo/Swag的基本介绍及使用教程,它极大地简化了API文档的编写工作,提高了开发效率。尝试在你的下一个Go项目中加入Swag,享受优雅的API文档管理吧!
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0192
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0121
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
fun-rec推荐系统入门教程,在线阅读地址:https://datawhalechina.github.io/fun-rec/Python03
so-large-lm大模型基础: 一文了解大模型基础知识01
项目优选
收起
暂无描述
Dockerfile
766
4.99 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
857
1.94 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
686
1.34 K
Ascend Extension for PyTorch
Python
721
884
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.08 K
1.1 K
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
458
443
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.01 K
262
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
151
253
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1 K
612