原始碼 github.com/wuyan94zl/GoApiServer
體驗 gorbacui.wuyan94zl.cn
使用
工作區直接拉取程式碼git clone https://github.com/wuyan94zl/GoApiServer
開始
首先把 .env.example
改為 .env
並配置資料庫連線,其他資訊隨情況修改
啟動服務 go run main.go
會看見如下路由
可以看到 /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
上面已經增加了 增刪改查等api功能
演示的api所有功能實現步驟
- 第一步:
git clone https://github.com/wuyan94zl/GoApiServer
- 第二步:
go run wuyan.go admin
和go 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 article
和 go run wuyan.go article route permission
以上操作後會增加文章的增、刪、改、詳細、分頁資料5個介面
增和改介面中欄位驗證為:
title:必填,長度在10到50之間
description:必填,長度在10到200之間
content:必填
admin_id:必填,必須是數字
詳細和分頁資料中:
資料會關聯查詢admin資訊
本作品採用《CC 協議》,轉載必須註明作者和本文連結