SQL+RESTful开源GO脚手架工具ginbro(gin and gorm’s brother) 详解

https://gocn.vip/article/1766

安装felix

  1. git clone https://github.com/dejavuzhou/felix
  2. cd felix
  3. go mod download
  4. go install
  5. echo "添加 GOBIN 到 PATH环境变量"
  6. echo "或者"
  7. go get github.com/dejavuzhou/felix
  8. echo "go build && ./felix -h"

What is Ginbro

  • Gin脚手架工具:因为工作中非常多次的使用mysql数据库 + gin + GORM 来开发RESTful API程序,所以后开发一个Go语言的RESTful APIs的脚手架工具
  • Ginbro代码来源:Ginrbo的代码迭代自github.com/dejavuzhou/ginbro
  • SPA二进制化工具:vuejs全家桶代码二进制化成go代码,编译的时候变成二进制,运行的时候直接加载到内存中,同时和gin API在一个域名下不需要再nginx中配置rewrite或者跨域,加快API访问速度

功能一:Gin+GORM_SQL RESTful 脚手架工具

工作原理

  1. 通过cobra 获取命令行参数
  2. 使用sql参数连接数据库
  3. 后去数据库表的名称和字段类型等数据库
  4. 数据库边的表名和字段信息,转换成 Swagger doc 规范字段 和 GORM 模型字段
  5. 使用标准库 text/template 生成swagger.yaml, GORM 模型文件, GIN handler 文件 …
  6. 使用 go fmt ./... 格式化代码
  7. 使用标准库archive/zip打包*.go config.toml ...代码,提供zip文件下载(命令行模式没有)

支持数据库大多数SQL数据库

  • mysql
  • SQLite
  • postgreSQL
  • mssql(TODO:: sqlserver)

ginbro 生成app代码包含功能简介

  • 每一张数据库表生成一个RESTful规范的资源(GET<pagination>/POST/GET<one>/PATCH/DELETE)
  • 支持API-json数据分页-和总数分页缓存,减少全表扫描
  • 支持golang-内存单机缓存缓存
  • 前端代码和API公用一个服务,减少跨域OPTION的请求时间和配置时间,同时完美支持前后端分离
  • 开箱支持jwt-token认证和Bearer Token 路由中间件
  • 开箱即用的logrus数据库
  • 开箱即用的viper配置文件
  • 开箱即用的swagger API 文档
  • 开箱即用的定时任务系统

项目演示地址

felix sshw 网页UI演示地址 用户名和密码都是admin

生成swagger API交互文档地址 http://ginbro.mojotv.cn/swagger/

msql生成go代码地址

bili命令行演示视频地址

命令行参数详解

  1. [root@ericzhou felix]# felix ginbro -h
  2. generate a RESTful APIs app with gin and gorm for gophers
  3. Usage:
  4. felix ginbro [flags]
  5. 示例:
  6. felix ginbro -a dev.wordpress.com:3306 -P go_package_name -n db_name -u db_username -p 'my_db_password' -d '~/thisDir'
  7. Flags:
  8. --authColumn string 使用bcrypt方式加密的用户表密码字段名称 (default "password")
  9. --authTable string 认知登陆用户表名称 (default "users")
  10. -a, --dbAddr string 数据库连接的地址 (default "127.0.0.1:3306")
  11. -c, --dbChar string 数据库字符集 (default "utf8")
  12. -n, --dbName string 数据库名称
  13. -p, --dbPassword string 数据库密码 (default "password")
  14. -t, --dbType string 数据库类型: mysql/postgres/mssql/sqlite (default "mysql")
  15. -u, --dbUser string 数据库用户名 (default "root")
  16. -d, --dir string golang代码输出的目录,默认是当前目录 (default ".")
  17. -h, --help 帮助
  18. -l, --listen string 生成go app 接口监听的地址 (default "127.0.0.1:5555")
  19. --pkg string 生成go app 包名称(go version > 1.12) 生成go.mod文件, eg: ginbroSon
  20. [root@ericzhou felix]#

web界面

对于那些喜欢使用命令行的同学,你们可以选择使用web界面来操作

  1. git clone https://github.com/dejavuzhou/felix
  2. cd felix
  3. go mod download
  4. go install
  5. echo "添加 GOBIN 到 PATH环境变量"
  6. echo "go build && ./felix -h"
  7. echo 打开Web界面
  8. felix sshw -h
  9. felix sshw
  10. echo "三秒钟之后会自动帮助你打开浏览器,如果如果你使用的windows或者mac系统"

1.登陆界面

默认用户名和密码都是 admin

ginrbo_00.png

2.填写数据库连接信息

ginrbo_01.png

3.配置app用户认证的表和字段

ginrbo_02.png

4.配置app 包名称,导出目录和监听地址

ginrbo_03.png

5.生成go代码

ginrbo_04.png

6.下载代码或cd者到指定目录

ginrbo_05.png

功能二:前端代码二进化,通过gin中间件整合到API服务

工作原理

  1. 遍历编译好的前端代码目录
  2. 使用archive/zip写入到bytes.buffer
  3. 格式化输出层 字符串常量的 go文件中
  4. 创建gin中间件,加载字符串处理,解析出文件
  5. 中间件path如果命中文件,这http 输出文件,否在交给下一个handler

参数说明

  1. $ felix ginbin -h
  2. 示例: felix ginbin -s dist -p staticbin
  3. Usage:
  4. felix ginbin [flags]
  5. Flags:
  6. -c, --comment string 代码注释说明.
  7. -d, --dest string 出输go代码到目录. (default ".")
  8. -f, --force 是否覆盖输出. (default true)
  9. -h, --help 帮助
  10. -m, --mtime 是否修改文件时间戳.
  11. -p, --package string 输出的包名称. (default "felixbin")
  12. -s, --src string 前端静态文件的目录地址. (default "dist")
  13. -t, --tags string go 语言的标签.
  14. -z, --zip 是否zip压缩.

使用说明:生成的二进制化go文件

vuejs/dist 使用 felix ginbin 生成的go文件 https://github.com/dejavuzhou/felix/blob/master/staticbin/gin_static.go

gin 路由应用二进制化的前端代码中间件如下:

import "github.com/dejavuzhou/felix/staticbin" //导入felix ginbin 生成的二进制化包

https://github.com/dejavuzhou/felix/blob/master/ssh2ws/ssh2ws.go

  1. r := gin.Default()
  2. r.MaxMultipartMemory = 32 << 20
  3. //sever static file in http's root path
  4. binStaticMiddleware, err := staticbin.NewGinStaticBinMiddleware("/")
  5. if err != nil {
  6. return err
  7. }
  8. r.Use(binStaticMiddleware)

引用和代码仓库

dejavuzhou/felix Golang 工具集

felix ginbro 命令逻辑代码目录

前端代码二进制化成gin中间件代码

文章来源 MojoTech

4 天前

ft_authoradmin  ft_create_time2019-05-27 12:16
 ft_update_time2019-05-27 12:16