基於golang的rbac許可權api管理服務(含自動生成CURD程式碼)

wuyan發表於2021-01-08

原始碼 github.com/wuyan94zl/GoApiServer
體驗 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 協議》,轉載必須註明作者和本文連結

相關文章