基于golang的rbac权限api管理服务(含自动生成CURD代码)

发布于 / 3个月前 - 更新于 / 3个月前


源码 https://github.com/wuyan94zl/GoApiServer
体验 http://gorbacui.wuyan94zl.cn

使用

工作区直接拉取代码
git clone https://github.com/wuyan94zl/GoApiServer

开始

首先把 .env.example 改为 .env 并配置数据库连接,其他信息随情况修改

启动服务 go run main.go 会看见如下路由

image.png

可以看到 /api/admin 开头的用户接口没有增删改查。使用如下命令构建

1、创建admin的CURD控制器

go run wuyan.go admin # 默认会在 app/controllers/admin 文件夹创建 curd.go 文件 # 改为 go run wuyan.go admin web 会在 app/controllers/web/admin 文件夹下 # web 参数可接受 web/console app/controllers/web/console/admin

2、创建admin的CURD控制器路由

go run wuyan.go admin route permission # go run wuyan.go admin route 后面跟文件夹 routes 下路由文件名 默认添加到 api.go # api.go 不需要认证的路由访问 # auth.go 需要认证的路由访问 # permission.go 需要认证且有权限的路由访问

3、此时重新运行服务 go run main.go

image.png
上面已经增加了 增删改查等api功能

演示的api所有功能实现步骤

  • 第一步: git clone https://github.com/wuyan94zl/GoApiServer
  • 第二步: go run wuyan.go admingo run wuyan.go admin route permission
  • 第三步: go run main.go
  • 以上操作就是演示地址中的api所有功能

构建CURD工具使用

需求:增加文章管理功能
1、创建数据表模型

type Article struct { Id uint64 `gorm:"column:id;primaryKey;autoIncrement;not null"json:"id"` Title string `validate:"required,min:10,max:50"search:"like"json:"title"` Description string `validate:"required,min:10,max:200"json:"description"` Content string `validate:"required"json:"content"` View uint64 AdminId uint64 `validate:"required,numeric"json:"admin_id"` Admin admin.Admin `gorm:"-"relationship:"belongTo"json:"admin"` CreatedAt time.Time `gorm:"column:created_at;index"json:"created_at"` UpdatedAt time.Time `gorm:"column:updated_at"json:"updated_at"` } //valiedate标签控制create和update的参数验证,valiedate参数详情请看 github.com/thedevsaddam/govalidator //如上创建的时候title和description必填且长度在10-50和10-200 //admin_id 必填且为数字 //search标签控制分页列表的查询方式(目前支持:like,=,>,<,!=。like为str%) //如上分页列表接口接收title关键字like查询 //relationship 为关联,如上查询的时候会关联出admin用户信息

2、bootstrap/auto_migrate.go init 函数中MigrateStruct map数据添加模型

MigrateStruct["article"] = Article{}

3、执行 go run wuyan.go articlego run wuyan.go article route permission

以上操作后会增加文章的增、删、改、详细、分页数据5个接口
增和改接口中字段验证为:
title:必填,长度在10到50之间
description:必填,长度在10到200之间
content:必填
admin_id:必填,必须是数字
详细和分页数据中:
数据会关联查询admin信息

本作品采用《CC 协议》,转载必须注明作者和本文链接