/2020/11/f9a6a500.jpg
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中文网】,希望能给您带来帮助,苟日新、日日新、又日新,生命不息,学习不止。