GRABC beego框架的rabc权限管理插件

最近抽时间写了一个beego框架的rabc插件。这个插件包括路由、权限、角色、用户角色绑定的功能。路由功能会自动扫描controller里面的方法,然后根据需要将路由授权给权限,权限授权给角色,角色分配给用户。grabc功能简单实用,在beego框架中安装只需要不到20行的代码,即可实现rabc的功能。

安装:

1go get github.com/codyi/grabc

配置:

1第一步:在你项目中的数据库中导入rabc.sql,生成对应数据表
2 
3第二步:在项目中引入grabc库(可以在项目中的main.go或router.go中引入)

在router.go或main.go中配置如下:

01//引入grabc库
02import "github.com/codyi/grabc"
03func init() {
04    //将路由注册到grabc,用于反射出对应的网址
05    grabc.RegisterController(&controllers.SiteController{})
06    grabc.RegisterController(&controllers.UserController{})
07    //注册用户系统模型到grabc,用于用户ID和grabc插件绑定
08    //注意:注册的这个用户模型,需要实现IUserModel中的方法
09    grabc.RegisterUserModel(&models.User{})
10    //增加忽律权限检查的页面
11    grabc.AppendIgnoreRoute("site", "login")
12    //403页面地址注册到grabc中,用于grabc插件禁止权限的页面跳转
13    grabc.Http_403("/site/nopermission")
14    //设置模板,为了让grabc更具有通用性,可以设置模板
15    //目前设置模板只支持传入模板的内容
16    grabc.SetLayout(libs.Grabc_layout, nil)
17}

添加好上面的配置之后,剩下就是在controller中增加权限判了,个人建议做一个BaseController,然后每个controller都继承这个base,然后在BaseController中的方法中增加grabc的权限检查,这样每个controller在请求之前都会先检查权限~~

1BaseController.go中Prepare方法中配置如下
2 
3//注册当前登录的用户,注意:user需要继承IUserIdentify接口
4grabc.RegisterIdentify(user)
5 
6if !grabc.CheckAccess(this.controllerName, this.actionName) {
7    this.redirect(this.URLFor("SiteController.NoPermission"))
8}

到此grabc的功能都加完了,是不是很简单~~~

注意:增加完权限判断之后,会发现很多页面都不能访问了,那么就在router.go或main.go中增加如下代码

1grabc.AppendIgnoreRoute("*", "*")

以上grabc将会忽律所有的权限检查,这时候需要去/route/index中增加路由,然后添加权限,角色和用户分配,都配置好之后,就可以将grabc.AppendIgnoreRoute(“*”, “*”)代码删掉,然后重启项目~~权限起作用了,是不是很简单~~

接口说明

01IUserModel接口
02 
03//用于定义用户model
04type IUserModel interface {
05    //用户列表返回可用用户的id和姓名
06    //参数:pageIndex 分页的页数
07    //参数:pageCount 每页显示的用户数量
08    //返回值:userList [用户ID]用户姓名,用户列表展示
09    //返回值:totalNum 全部的用户数目,用于计算分页的数量
10    //返回值:err
11    UserList(pageIndex, pageCount int) (userList map[int]string, totalNum int, err error)
12    //根据用户ID获取用户姓名
13    FindNameById(id int) string
14}
15IUserIdentify接口
16 
17type IUserIdentify interface {
18    GetId() int //返回当前登录用户的ID
19}

更过详细文档请访问:https://github.com/codyi/grabc

发表评论

电子邮件地址不会被公开。

您可以使用这些 HTML 标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>