Heim  >  Artikel  >  php教程  >  thinkphp教程之RBAC详解1之准备工作

thinkphp教程之RBAC详解1之准备工作

WBOY
WBOYOriginal
2016-06-07 11:44:30968Durchsuche

很多人不明白RBAC怎么用,其实说难也不难,大概看一下RBAC类就明白了
我们通过分析RBAC类来理解这个权限是如何实现的。
首先我们先简单理解一下RBAC,顾名思义,RBAC是基于角色的权限设计。既然根据角色去分权限,那么我们就得有角色表,权限表,角色对应权限表,这是最基本的。角色是什么,就是你的身份,你的职位,也就是一个用户拥有这个身份才能获得某种权力。插一句,角色下辖的是用户,一个角色组可以有多个用户,一个用户也可能有多个角色,多对多的关系。
打开RBAC.class.php,你会发现官方已经告诉你,需要准备的东西。首先是配置文件需要设置的东西如下:// 配置文件增加设置<br> // USER_AUTH_ON 是否需要认证<br> // USER_AUTH_TYPE 认证类型 1 登录认证 2 实时认证<br> // USER_AUTH_KEY 认证识别号<br> // REQUIRE_AUTH_MODULE  需要认证模块<br> // NOT_AUTH_MODULE 无需认证模块<br> // USER_AUTH_GATEWAY 认证网关<br> // RBAC_DB_DSN  数据库连接DSN<br> // RBAC_ROLE_TABLE 角色表名称<br> // RBAC_USER_TABLE 用户表名称<br> // RBAC_ACCESS_TABLE 权限表名称<br> // RBAC_NODE_TABLE 节点表名称其次需要准备的数据表:/*<br> -- --------------------------------------------------------<br> CREATE TABLE IF NOT EXISTS `think_access` (<br>   `role_id` smallint(6) unsigned NOT NULL,<br>   `node_id` smallint(6) unsigned NOT NULL,<br>   `level` tinyint(1) NOT NULL,<br>   `module` varchar(50) DEFAULT NULL,<br>   KEY `groupId` (`role_id`),<br>   KEY `nodeId` (`node_id`)<br> ) ENGINE=MyISAM DEFAULT CHARSET=utf8;<br> <br> CREATE TABLE IF NOT EXISTS `think_node` (<br>   `id` smallint(6) unsigned NOT NULL AUTO_INCREMENT,<br>   `name` varchar(20) NOT NULL,<br>   `title` varchar(50) DEFAULT NULL,<br>   `status` tinyint(1) DEFAULT '0',<br>   `remark` varchar(255) DEFAULT NULL,<br>   `sort` smallint(6) unsigned DEFAULT NULL,<br>   `pid` smallint(6) unsigned NOT NULL,<br>   `level` tinyint(1) unsigned NOT NULL,<br>   PRIMARY KEY (`id`),<br>   KEY `level` (`level`),<br>   KEY `pid` (`pid`),<br>   KEY `status` (`status`),<br>   KEY `name` (`name`)<br> ) ENGINE=MyISAM  DEFAULT CHARSET=utf8;<br> <br> CREATE TABLE IF NOT EXISTS `think_role` (<br>   `id` smallint(6) unsigned NOT NULL AUTO_INCREMENT,<br>   `name` varchar(20) NOT NULL,<br>   `pid` smallint(6) DEFAULT NULL,<br>   `status` tinyint(1) unsigned DEFAULT NULL,<br>   `remark` varchar(255) DEFAULT NULL,<br>   PRIMARY KEY (`id`),<br>   KEY `pid` (`pid`),<br>   KEY `status` (`status`)<br> ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 ;<br> <br> CREATE TABLE IF NOT EXISTS `think_role_user` (<br>   `role_id` mediumint(9) unsigned DEFAULT NULL,<br>   `user_id` char(32) DEFAULT NULL,<br>   KEY `group_id` (`role_id`),<br>   KEY `user_id` (`user_id`)<br> ) ENGINE=MyISAM DEFAULT CHARSET=utf8;<br> */当然你得有你的用户表比如think_user. 好,这是最基本的准备工作。

AD:真正免费,域名+虚机+企业邮箱=0元

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn