使用 Entrust 扩展包在 Laravel 5 中实现 RBAC 权限管理与安装配置
Posted PHP自学中心
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用 Entrust 扩展包在 Laravel 5 中实现 RBAC 权限管理与安装配置相关的知识,希望对你有一定的参考价值。
php自学中心网址:http://www.startphp.cn
文章正文
这里分享一套laravel5.8从基础到实战【教程+源码+文档】,很多初学者或者开始接触laravel的同学都不知道如何学习,小编推荐的这视频教程正好适合你,又是最新版的,值得你去探究一二,先把laravel的基础与核心部分学好来,以后不管更新了哪个版本,对你来说都不是问题的咯。视频教程共93节,每周更新两章,以下提供百度网盘链接+提取码
Laravel5.8从入门到实战视频教程+源码【93节】
链接:http://www.startphp.cn/detail/55
Entrust为我们在Laravel中实现基于角色的权限管理(RBAC)提供了简洁灵活的方式。
1、安装
想要在Laravel中使用Entrust,首先需要通过Composer来安装其依赖包:
composer require zizaco/entrust 5.2.x-dev
安装完成后需要在config/app.php
中注册服务提供者到providers
数组:
Zizaco\Entrust\EntrustServiceProvider::class,
同时在该配置文件中注册相应门面到aliases
数组:
'Entrust' => Zizaco\Entrust\EntrustFacade::class,
如果你想要使用中间件(要求Laravel 5.1或更高版本)还需要添加如下代码到app/Http/Kernel.php
的routeMiddleware
数组:
'role' => \Zizaco\Entrust\Middleware\EntrustRole::class,
'permission' => \Zizaco\Entrust\Middleware\EntrustPermission::class,
'ability' => \Zizaco\Entrust\Middleware\EntrustAbility::class,
2、配置
在配置文件config/auth.php
中设置合适的值,Entrust会使用这些配置值来选择相应的用户表和模型类:
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
'table' => 'users',
],
],
你还可以发布该扩展包的配置以便后续自定义相关表名以及模型类的命名空间:
php artisan vendor:publish
该命令会在config
目录下创建一个entrust.php
文件。
3、用户角色权限表
接下来我们使用Entrust提供的迁移命令生成迁移文件:
php artisan entrust:migration
然后通过以下命令生成相应的数据表:
php artisan migrate
最终会生成4张新表:
roles
—— 存储角色permissions
—— 存储权限role_user
—— 存储角色与用户之间的多对多关系permission_role
—— 存储角色与权限之间的多对多关系
4、模型类
Role
我们需要创建Role模型类app/Role.php
并编辑其内容如下:
<?php namespace App;
use Zizaco\Entrust\EntrustRole;
class Role extends EntrustRole
{
}
Role
模型拥有三个主要属性:
name
—— 角色的唯一名称,如“admin”,“owner”,“employee”等display_name
—— 人类可读的角色名,例如“后台管理员”、“作者”、“雇主”等description
—— 该角色的详细描述
display_name
和description
属性都是可选的,在数据库中的相应字段默认为空。
Permission
接下来创建Permission模型app/Permission.php
并编辑其内容如下:
<?php namespace App;
use Zizaco\Entrust\EntrustPermission;
class Permission extends EntrustPermission
{
}
Permission
模型也有三个主要属性:
name
—— 权限的唯一名称,如“create-post”,“edit-post”等display_name
—— 人类可读的权限名称,如“发布文章”,“编辑文章”等description
—— 该权限的详细描述
User
接下来我们在User
模型中使用EntrustUserTrait
:
<?php
namespace App;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Zizaco\Entrust\Traits\EntrustUserTrait;
class User extends Authenticatable
{
use Notifiable;
use EntrustUserTrait;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
}
这将会建立User
与Role
之间的关联关系:在User
模型中添加roles()
、hasRole($name)
、can($permission)
以及ability($roles,$permissions,$options)
方法。
软删除
使用Entrust提供的迁移命令生成的关联关系表中默认使用了onDelete('cascade')
以便父级记录被删除后移除其对应的关联关系。如果你由于某种原因不能在数据库中使用级联删除,那么可以在EntrustRole
、EntrustPermission
类以及HasRole
trait提供的事件监听器中手动删除关联表中的记录。如果模型使用了软删除,那么当不小心误删除数据时,事件监听器将不会删除关联表数据。不过,由于Laravel事件监听器的局限性,所以暂时无法区分是调用delete()
还是forceDelete()
,基于这个原因,在你删除一个模型之前,必须手动删除所有关联数据(除非你的数据表使用了级联删除):
$role = Role::findOrFail(1); // 获取给定权限
// 正常删除
$role->delete();
// 强制删除
$role->users()->sync([]); // 删除关联数据
$role->perms()->sync([]); // 删除关联数据
$role->forceDelete(); // 不管透视表是否有级联删除都会生效
以上是文章全部内容,有学习与经验交流的可以加小编为好友。有技术问题可以一起探讨与交流,如果你是PHP的,小编也可以拉你进微信技术群,交流与学习!
跟着小编学习laravel5
长按二维码加好友,备注码农
学习 | 交流 | 分享 | 文章
以上是关于使用 Entrust 扩展包在 Laravel 5 中实现 RBAC 权限管理与安装配置的主要内容,如果未能解决你的问题,请参考以下文章
在 Vue JS 和 Laravel 5.1 + Entrust 中检查特定角色的权限
Laravel 5.2 Entrust:如果他手动添加受限URL,则重定向用户
Laravel 5.5 Entrust使用中间件授予路由组权限失败
Entrust - Laravel 用户权限系统解决方案 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 - Powered by PHPHub