mysql - 设计用户角色和权限系统的最佳实践?

我需要将用户角色和权限系统添加到我使用 PHP/MySQL 构建的 Web 应用程序中。我想要这个功能:

  1. 一个根用户可以创建子根、组、规则和普通用户(所有权限)。
  2. 子根只能为他/她自己的组创建规则、权限和用户(没有组)。
  3. 根据组 root 分配给他的权限,用户可以访问由他或他的组创建的内容。

我需要系统足够灵活,以便为内容分配新角色和权限。

我有一个 users 表存储组键和其他信息。目前我在每个内容表中使用两个字段,即 createdByCreatedByGroup,并以此作为某个用户是否具有权限的点。但它不够灵活,因为对于每一个新内容,我都必须通过所有的数据更新和权限更新。请通过讨论您的架构设计最佳实践来帮助我。

最佳答案

我认为按位运算符是实现用户权限的最佳方式。 在这里,我将展示我们如何使用 MySQL 来实现它。

下面是带有一些示例数据的示例表:

表 1:存储权限名称的权限表,例如 1、2、4、8.. 等(2 的倍数)

CREATE TABLE IF NOT EXISTS `permission` (
  `bit` int(11) NOT NULL,
  `name` varchar(50) NOT NULL,
  PRIMARY KEY (`bit`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

在表格中插入一些示例数据。

INSERT INTO `permission` (`bit`, `name`) VALUES
(1, 'User-Add'),
(2, 'User-Edit'),
(4, 'User-Delete'),
(8, 'User-View'),
(16, 'Blog-Add'),
(32, 'Blog-Edit'),
(64, 'Blog-Delete'),
(128, 'Blog-View');

表 2:用于存储用户 ID、名称和角色的用户表。角色将被计算为权限的总和。
示例:

如果用户 'Ketan' 拥有 'User-Add' (bit=1) 和 'Blog-Delete' (bit-64) 权限,则角色将为 65 (1+64)。
如果用户“Mehata”拥有“Blog-View”(bit=128)和“User-Delete”(bit-4)的权限,那么角色将为 132(128+4)。

CREATE TABLE IF NOT EXISTS `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) NOT NULL,
  `role` int(11) NOT NULL,
  `created_date` datetime NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1;

样本数据-

INSERT INTO `user` (`id`, `name`, `role`, `created_date`)
   VALUES (NULL, 'Ketan', '65', '2013-01-09 00:00:00'),
   (NULL, 'Mehata', '132', '2013-01-09 00:00:00');

用户的加载权限 登录后如果我们想加载用户权限,那么我们可以在下面查询以获得权限:

SELECT permission.bit,permission.name  
   FROM user LEFT JOIN permission ON user.role & permission.bit
 WHERE user.id = 1

这里 user.role "&"permission.bit 是一个按位运算符,输出为 -

User-Add - 1
Blog-Delete - 64

如果我们想检查特定用户是否拥有用户编辑权限-

  SELECT * FROM `user` 
     WHERE role & (select bit from permission where name='user-edit')

输出 = 无行。

您还可以查看:http://sforsuresh.in/implemention-of-user-permission-with-php-mysql-bitwise-operators/

https://stackoverflow.com/questions/333620/

相关文章:

php - 如何使用 Laravel 4 Eloquent 连接列?

php - PDO fetchAll 将键值对分组到 assoc 数组中

php - 选择在 wp_usermeta 表中的多行上具有合格数据的用户

mysql - 仅获取mysql中时间戳中的日期

mysql - 列计数与第 1 行的值计数不匹配

php - MySQL 删除多列

mysql - INSERT ... 使用 WHERE 进行重复的 key 更新?

php - DateTime 类的对象无法转换为字符串

php - 从字段不匹配条件的表中选择

python - 如何安装 MySQLdb 包? (导入错误 : No module named s