返回介绍

完成 Entrust 的配置

发布于 2024-09-07 20:21:06 字数 3277 浏览 0 评论 0 收藏 0

完成 Entrust 的配置

安装 zizaco/entrust Package

zizaco/entrust 是 Laravel 下基于角色的权限管理方案。

1.修改文件 composer.json

"require": {
  "php": ">=5.5.9",
  "laravel/framework": "5.1.*",
  "gregwar/captcha": "1.*",
  "zizaco/entrust": "dev-laravel-5"
},

2.在终端运行命令

composer install

// or

composer update

3.在文件 config/app.phpproviders 数组和 aliase 数组分别添加

// providers
Zizaco\Entrust\EntrustServiceProvider::class

// aliase
'Entrust' => Zizaco\Entrust\EntrustFacade::class,

4.在文件 app/Http/Kernel.php$routeMiddleware 添加

'role' => Zizaco\Entrust\Middleware\EntrustRole::class,
'permission' => Zizaco\Entrust\Middleware\EntrustPermission::class,
'ability' => Zizaco\Entrust\Middleware\EntrustAbility::class,

5.Entrust 会根据文件 config/auth.phpmodel 来选择用户模型,如下:

'model' => App\Models\User::class

执行以下命令生成配置文件 config/entrust.php

php artisan vendor:publish

修改配置文件 entrust.php 如下:

'role'=>'App\Models\Role'
'permission'=>'App\Models\Permission'

6.生成数据库迁移文件并执行

php artisan entrust:migration
php artisan migrate

7.生成自动加载

composer dump-autoload

管理模型

为了使用 Entrust,我们需要新建两个模型,在终端运行以下命令:

// 角色模型
php artisan make:model Models/Role

// 权限模型
php artisan make:model Models/Permission

Role.php

<?php
namespace App\Models;

use Zizaco\Entrust\EntrustRole;

class Role extends EntrustRole
{
  protected $guarded = [];
}

Permission.php

<?php
namespace App\Models;

use Zizaco\Entrust\EntrustPermission;

class Permission extends EntrustPermission
{
  protected $guarded = [];
}

为了配合 Entrust 的使用,需要修改 User.php 的代码

<?php

namespace App\Models;

use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Foundation\Auth\Access\Authorizable;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;
use Zizaco\Entrust\Traits\EntrustUserTrait;

class User extends Model implements AuthenticatableContract,
  AuthorizableContract,
  CanResetPasswordContract
{
  use Authenticatable, Authorizable, CanResetPassword, EntrustUserTrait{
    Authorizable::can insteadof  EntrustUserTrait;
    EntrustUserTrait::can as hasPermission;
  }

  /**
   * The database table used by the model.
   *
   * @var string
   */
  protected $table = 'users';

  /**
   * The attributes that are mass assignable.
   *
   * @var array
   */
  protected $fillable = ['name', 'email', 'password'];

  /**
   * The attributes excluded from the model's JSON form.
   *
   * @var array
   */
  protected $hidden = ['password', 'remember_token'];
}

完成上述所有操作之后,Entrust 的配置就完成了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文