思考并回答以下问题:
基于 GIN + Gorm 2.0 + CASBIN + WIRE 实现的RBAC权限管理脚手架,目标是提供一套轻量的中后台开发框架,方便、快速的完成业务需求的开发。
特性
- 遵循
RESTful API
设计规范 & 基于接口的编程规范 - 基于
GIN
框架,提供了丰富的中间件支持(JWTAuth、CORS、RequestLogger、RequestRateLimiter、TraceID、CasbinEnforce、Recover、GZIP) - 基于
Casbin
的 RBAC 访问控制模型 — 权限控制可以细粒度到按钮 & 接口 - 基于
Gorm 2.0
的数据库访问层 - 全功能 ORM - 基于
WIRE
的依赖注入 — 依赖注入本身的作用是解决了各个模块间层级依赖繁琐的初始化过程 - 基于
Logrus & Context
实现了日志输出,通过结合 Context 实现了统一的 TraceID/UserID 等关键字段的输出(同时支持日志钩子写入到Gorm
) - 基于
JWT
的用户认证 — 基于 JWT 的黑名单验证机制 - 基于
Swaggo
自动生成Swagger
文档 — 独立于接口的 mock 实现 - 基于
net/http/httptest
标准包实现了 API 的单元测试 - 基于
go mod
的依赖管理(国内源可使用:https://goproxy.cn/)
依赖工具
1 | go get -u github.com/cosmtrek/air |
- air — Live reload for Go apps
- wire — Compile-time Dependency Injection for Go
- swag — Automatically generate RESTful API documentation with Swagger 2.0 for Go.
依赖框架
- Gin — The fastest full-featured web framework for Go.
- GORM — The fantastic ORM library for Golang
- Casbin — An authorization library that supports access control models like ACL, RBAC, ABAC in Golang
- Wire — Compile-time Dependency Injection for Go
快速开始
也可以使用国内源:https://gitee.com/lyric/gin-admin
1 | $ git clone https://github.com/LyricTian/gin-admin |
启动成功之后,可在浏览器中输入地址进行访问:http://127.0.0.1:10088/swagger/index.html
生成swagger
文档
1 | # 基于Makefile |
生成依赖注入文件
1 | # 基于Makefile |
gin-admin-cli工具使用
创建项目
1 | gin-admin-cli new -d test-gin-admin -p test-gin-admin -m |
快速生成业务模块
创建模板 task.yaml
1 | name: Task |
执行生成命令并运行
1 | cd test-gin-admin |
前端工程
- 基于Ant Design React版本的实现:gin-admin-react(也可使用国内源:https://gitee.com/lyric/gin-admin-react)
目录结构
1 | ├── cmd |