使用Beego创建API项目并自动化文档

最近需要使用Go写一个Web API项目,可以使用Beego与Gin来写此类项目,还是非常方便的,这里就介绍一下使用Beego来创建的Web API项目并自动化文档的方法。

使用Gin创建API项目并自动化文档参见:使用Gin编写Web API项目并自动化文档

一、准备环境

go install github.com/beego/bee/v2@latest

二、创建API项目

bee api api

在这里插入图片描述

1. 下载项目依赖

$ cd api
$ go mod tidy

在这里插入图片描述

此时项目目录结构如下:

$ tree
.
├── conf
│   └── app.conf
├── controllers
│   ├── object.go
│   └── user.go
├── go.mod
├── go.sum
├── main.go
├── models
│   ├── object.go
│   └── user.go
├── routers
│   └── router.go
└── tests
    └── default_test.go

6 directories, 10 files

2. 生成路由

bee generate routers

在这里插入图片描述

该命令会生成routers/commentsRouter.go文件。

$ tree
.
├── conf
│   └── app.conf
├── controllers
│   ├── object.go
│   └── user.go
├── go.mod
├── go.sum
├── main.go
├── models
│   ├── object.go
│   └── user.go
├── routers
│   ├── commentsRouter.go
│   └── router.go
└── tests
    └── default_test.go

6 directories, 11 files

此时可以在浏览器中浏览:http://127.0.0.1:8080/v1/user/

在这里插入图片描述
注意,这里不能使用https

三、自动化文档与测试

每次手动测试API还是比较繁琐的,为了方便测试,可以使用swagger来进行API辅助测试。

bee run -gendoc=true -downdoc=true

在这里插入图片描述

此时默认使用的是https://petstore.swagger.io/v2/swagger.json配置文件

在这里插入图片描述

可以手动将前面的路径去掉,只保留swagger.json,然后测试,会发现有问题:

	
Failed to fetch.
Possible Reasons:

CORS
Network Failure
URL scheme must be "http" or "https" for CORS request.

在这里插入图片描述

需要修改swagger/index.html

在这里插入图片描述

url: "https://petstore.swagger.io/v2/swagger.json"替换成url: "/swagger/swagger.json"。再测试就正常了:

在这里插入图片描述

如何写注释,让swagger自动生成接口文档,可以参考:https://beego.wiki/zh-cn/docs/advantage/docs/

相关推荐

  1. react 实现自动创建api 请求文件

    2024-05-10 19:38:06       12 阅读
  2. Flask 项目自动生成 API 文档的高效实践

    2024-05-10 19:38:06       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-10 19:38:06       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-10 19:38:06       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-10 19:38:06       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-10 19:38:06       20 阅读

热门阅读

  1. 秒杀系统架构设计-01

    2024-05-10 19:38:06       12 阅读
  2. uniapp——预览图片

    2024-05-10 19:38:06       9 阅读
  3. 基于springboot的校园管理系统源码数据库

    2024-05-10 19:38:06       12 阅读
  4. 使用vscode时快速生成console.log()

    2024-05-10 19:38:06       10 阅读
  5. 了解Ansible Playbook

    2024-05-10 19:38:06       10 阅读
  6. 力扣 300. 最长递增子序列 python AC

    2024-05-10 19:38:06       12 阅读
  7. LeetCode hot100-31-G

    2024-05-10 19:38:06       11 阅读
  8. Golang 并发 Mutex 互斥锁的使用

    2024-05-10 19:38:06       12 阅读
  9. SpringBoot笔记

    2024-05-10 19:38:06       8 阅读