• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    使用Entrust扩展包在laravel 中实现RBAC的功能

    想要在Laravel中使用Entrust,首先需要通过Composer来安装其依赖包:

    composer require zizaco/entrust 5.2.x-de

    安装完成后需要在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,

    ②配置

    在配置文件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

    如果执行上面的 命令出现 以下的错误:

     

    处理方法: vendor-> zizaco-> entrust-> src-> commands-> MigrationCommand.php ,并将”fire“方法更改为”handle“ 然后通过以下命令生成相应的数据表:

    php artisan migrate

    最终会生成4张新表:

    4、模型类

    Role
    我们需要创建Role模型类app/Role.php并编辑其内容如下:

    ?php namespace App;
    use Zizaco\Entrust\EntrustRole;
    class Role extends EntrustRole
    {
    }

    Role模型拥有三个主要属性:

    Permission

    接下来创建Permission模型app/Permission.php并编辑其内容如下:

    ?php namespace App;
    use Zizaco\Entrust\EntrustPermission;
    class Permission extends EntrustPermission
    {
    }

    Permission模型也有三个主要属性:

    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(); // 不管透视表是否有级联删除都会生效

    总结

    到此这篇关于使用Entrust扩展包在laravel 中实现RBAC的功能的文章就介绍到这了,更多相关Entrust扩展包实现RBAC内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • 如何使用VSCode配置Rust开发环境(Rust新手教程)
    • Rust 能够取代 C 语言吗
    • 改进 JavaScript 和 Rust 的互操作性并深入认识 wasm-bindgen 组件
    • 完美解决node.js中使用https请求报CERT_UNTRUSTED的问题
    • C和Java没那么香了,Serverless时代Rust即将称王?
    上一篇:PHP代码加密的方法总结
    下一篇:Laravel框架下的Contracts契约详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    使用Entrust扩展包在laravel 中实现RBAC的功能 使用,Entrust,扩展,包在,laravel,