Go Gin Gorm Casbin权限管理实现 - 2. 使用Gorm存储Casbin权限配置以及`增删改查`
package main
import (
"github.com/gin-gonic/gin"
"github.com/casbin/casbin/v2"
gormadapter "github.com/casbin/gorm-adapter/v3"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
)
func main() {
// 初始化数据库
db, err := gorm.Open(sqlite.Open("casbin.db"), &gorm.Config{})
if err != nil {
panic(err)
}
// 初始化Casbin
a, err := gormadapter.NewAdapter("sqlite3", "casbin.db")
if err != nil {
panic(err)
}
e, err := casbin.NewSyncer(a)
if err != nil {
panic(err)
}
// 使用Casbin
enforcer, err := casbin.NewEnforcer("model.conf", a)
if err != nil {
panic(err)
}
// 创建Gin路由
r := gin.Default()
// 定义API路由
r.GET("/api/permission", func(c *gin.Context) {
// 检查权限
if enforcer.Enforce("alice", "data1", "read") {
c.JSON(200, gin.H{"message": "access allowed"})
} else {
c.JSON(403, gin.H{"message": "access denied"})
}
})
// 启动服务器
r.Run(":8080")
}
这个代码实例展示了如何在Go语言的Gin框架中使用Gorm作为数据库适配器,并结合Casbin访问控制模型来管理权限。它演示了如何初始化数据库、Casbin enforcer,并在Gin路由中使用权限检查。这个例子简洁且易于理解,对于学习如何在Web应用程序中实现权限管理具有很好的教育价值。
评论已关闭