thinkPHP5使用Rabc实现权限管理(2)
(3):role(角色表)
DROP TABLE IF EXISTS `###role`; CREATE TABLE `###role` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL DEFAULT '' COMMENT '角色名', `description` varchar(200) NOT NULL DEFAULT '' COMMENT '角色描述', `status` smallint(4) unsigned NOT NULL DEFAULT '0' COMMENT '状态1正常0未启用', `sort_num` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '排序值', PRIMARY KEY (`id`), KEY `idx_role` (`status`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='角色表';
(4):role_permission(角色权限关联表)
DROP TABLE IF EXISTS `###role_permission`; CREATE TABLE `###role_permission` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `role_id` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '角色编号', `permission_id` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '权限编号', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='角色权限对应表';
(5):user(用户表)
DROP TABLE IF EXISTS `###user`; CREATE TABLE `###user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `user_name` varchar(50) NOT NULL DEFAULT '' COMMENT '用户名', `password` varchar(64) NOT NULL DEFAULT '' COMMENT '用户密码', `mobile` varchar(20) NOT NULL DEFAULT '' COMMENT '手机号码', `last_login_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最后一次登录时间', `status` smallint(4) unsigned NOT NULL DEFAULT '0' COMMENT '状态0禁用1正常', `create_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '账号创建时间', `update_time` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '信息更新时间', PRIMARY KEY (`id`), KEY `idx_user` (`user_name`,`mobile`,`status`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表';
(6):user_role(用户角色关联表)
DROP TABLE IF EXISTS `###user_role`; CREATE TABLE `###user_role` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `user_id` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '用户id', `role_id` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '角色id', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户角色对应关系';
2:rbac的相关操作
(1)创建权限分组
//实例化rbac $rbac = new Rbac(); //创建权限分组 $rbac->savePermissionCategory([ 'name' => '用户管理组', 'description' => '网站用户的管理', 'status' => 1 ]);
当savePermissionCategory方法中包含了主键id时为编辑权限分组
(2)创建权限节点
//实例化rbac $rbac = new Rbac(); //创建权限节点 $rbac->createPermission([ 'name' => '文章列表查询', 'description' => '文章列表查询', 'status' => 1, 'type' => 1,//type为权限类型1为后端权限2为前端权限 'category_id' => 1,//权限分组的id 'path' => 'article/content/list', ]);
内容版权声明:除非注明,否则皆为本站原创文章。