2019年PHP热门框架之laravel:laravel-admin权限管理与实现原理

我们先使用laravel-admin后台实现一个权限管理
1.添加一个用户管理的权限

标识(slug)是用来标记权限的唯一标识,全局唯一。名称(name)是这个权限的展示名称,要让人一眼看明白这个权限是做什么用的

2.添加一个角色

3.创建管理员

这样的话,我们就有了kaka这个用户,然后我们来登录一下,我们只给了这个kaka一个用户管理的权限,这样就设置成功了。

解析权限管理
实现权限管理数据表

1.我们先看看admin_user表,这只是一个单纯保存后台管理员的一个表。

2.下面就是我们的角色表,也就是我们在laravel-admin后台添加角色就会添加到这个表里面。

3.下来就是重点来了,我们的角色用户表。
我们可以看到角色用户表,里边有个角色id跟用户id的外键,这个表就是把管理员跟角色联系在一起了。

4.下面就是权限表,这个表是存储的所有的权限。

5.最后就是我们的角色权限表了。

权限总结
上边给大家看了具体的表结构,其实这个不是很复杂,我们在简单的阐述一下:
首先我们在做权限管理的时候为了什么,那么就是希望不同的管理员看到不同的内容。
1.那么我们需要的第一个表就是后台管理员表admin_users,这个表只是用来存储管理员账号和密码;
2.在一个基本那就是我们的角色表admin_roles,这个表的性质跟管理员表是一样的也是来存储角色的信息;
3.那么这个时候就需要一个表来关联我们的admin_users和admin_roles表,那就是admin_role_users,这个表只是一个中间件表,里边只需要把管理员跟角色的对应关系存储即可;
4.上边都完善了后我们就需要一个权限表了admin_permissions,这个表就是存储我们所有的权限;
5.那么我们的权限是不是需要跟角色关联呢!只有这样用户才可以从自己的角色中获取到自己拥有的权限,那么就需要一个权限角色表admin_role_permissions。
以上就是laravel-admin权限管理与实现原理的详细内容,更多请关注其它相关文章!
相关推荐
-
MySQL 由于 Java 日期 LocalDateTime 数据精度引发的线上问题
MySQL 由于 Java 日期 LocalDateTime 数据精度引发的线上问题2025-04-02 00:59:31 -
MySQL最常用分组聚合函数2025-04-02 00:55:56
-
NGINX: 轮询调度、加权轮询调度、平滑加权轮询调度2025-04-02 00:55:49
-
在Windows平台上安装Nginx并设置开机自动启动服务2025-04-02 00:47:04
-
PHP判断文件或者目录是否可写,兼容windows/linux系统
PHP判断文件或者目录是否可写,兼容windows/linux系统2025-04-02 00:27:54