文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
完成 Entrust 的配置
完成 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.php
的 providers
数组和 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.php
的 model
来选择用户模型,如下:
'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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论