laravel-admin权限管理与实现原理

2020-11-10,,,

/2020/11/f9a6a500.jpg

我们先使用laravel-admin后台实现一个权限管理

1.添加一个用户管理的权限

/2020/11/a325fa06.png" /2020/11/a325fa06.png" alt="https://i.vszh.cn/wk/file/2020/11/a325fa06.png" width="800" height="250" border="0" vspace="0" style="width: 800px;height: 250px

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

/2020/11/89942dbf.png" /2020/11/89942dbf.png" alt="https://i.vszh.cn/wk/file/2020/11/89942dbf.png" width="800" height="600" border="0" vspace="0" style="width: 800px;height: 600px

2.添加一个角色

/2020/11/4d9e6306.png" /2020/11/4d9e6306.png" alt="https://i.vszh.cn/wk/file/2020/11/4d9e6306.png" width="800" height="450" border="0" vspace="0" style="width: 800px;height: 450px

3.创建管理员

/2020/11/a5c19435.png" /2020/11/a5c19435.png" alt="https://i.vszh.cn/wk/file/2020/11/a5c19435.png" width="800" height="400" border="0" vspace="0" style="width: 800px;height: 400px

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

/2020/11/849a6029.png" /2020/11/849a6029.png" alt="https://i.vszh.cn/wk/file/2020/11/849a6029.png" width="800" height="450" border="0" vspace="0" style="width: 800px;height: 450px

解析权限管理

实现权限管理数据表

/2020/11/7a5ddd59.png" /2020/11/7a5ddd59.png" alt="055abf7be945bdc47930a0869279b77.png

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

/2020/11/5e21cf1e.png" /2020/11/5e21cf1e.png" alt="53b24542e283dee730095d58a1026c6.png

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

/2020/11/a5c19435-1.png" /2020/11/a5c19435-1.png" alt="9665989a919abca33cde401fafa86c2.png

3.下来就是重点来了,我们的角色用户表。

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

/2020/11/8487d75b.png" /2020/11/8487d75b.png" alt="e62d5c1298f4c92c7510b302a84afa3.png

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

/2020/11/ddb7beef.png" /2020/11/ddb7beef.png" alt="5f6acfdbf251da2d25edfb6ad914304.png

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

/2020/11/7ef31411.png" /2020/11/7ef31411.png" alt="b3bed51e9d2b4c926b57236b117b396.png

权限总结

上边给大家看了具体的表结构,其实这个不是很复杂,我们在简单的阐述一下:

首先我们在做权限管理的时候为了什么,那么就是希望不同的管理员看到不同的内容。

1.那么我们需要的第一个表就是后台管理员表admin_users,这个表只是用来存储管理员账号和密码;

2.在一个基本那就是我们的角色表admin_roles,这个表的性质跟管理员表是一样的也是来存储角色的信息;

3.那么这个时候就需要一个表来关联我们的admin_users和admin_roles表,那就是admin_role_users,这个表只是一个中间件表,里边只需要把管理员跟角色的对应关系存储即可;

4.上边都完善了后我们就需要一个权限表了admin_permissions,这个表就是存储我们所有的权限;

5.那么我们的权限是不是需要跟角色关联呢!只有这样用户才可以从自己的角色中获取到自己拥有的权限,那么就需要一个权限角色表admin_role_permissions。

python学习网,大量的免费laravel入门教程,欢迎在线学习!

以上就是laravel-admin权限管理与实现原理的详细内容,更多请关注北冥有鱼其它相关文章!

本文转载自【PHP中文网】,希望能给您带来帮助,苟日新、日日新、又日新,生命不息,学习不止。

《laravel-admin权限管理与实现原理.doc》

下载本文的Word格式文档,以方便收藏与打印。