📜  laravel 权限 spatie 缓存清除 - PHP (1)

📅  最后修改于: 2023-12-03 15:02:37.366000             🧑  作者: Mango

Laravel 权限 Spatie 缓存清除 - PHP

简介

本文将介绍如何在 Laravel 中使用 Spatie 权限扩展包,以及如何清除缓存以避免权限变更不生效的问题。

Spatie 权限扩展包

Spatie 权限扩展包是 Laravel 的一个开源扩展包,用于处理应用程序中的权限管理。

它支持多种用户和角色管理策略,并且可以轻松地与 Laravel 应用程序集成。

缓存清除

当使用 Artisan 命令或编辑器生成代码时,应用程序的缓存会被更新。

这意味着在缓存刷新之前意图对代码进行的任何更改都将不会反映在应用程序中,从而导致意外结果。

安装

在开始之前,请确保 Laravel 安装有 Composer。

安装 Spatie 权限扩展包:

composer require spatie/laravel-permission
配置

在安装好扩展包之后,您可以在 config/app.php 中注册提供程序和 Facade:

'providers' => [
    // ...
    Spatie\Permission\PermissionServiceProvider::class,
];

'aliases' => [
    // ...
    'Permission' => Spatie\Permission\Facades\Permission::class,
];

运行数据库迁移以为权限管理创建必要的表格:

php artisan migrate
使用
新建角色

您可以使用 Role 类创建新的角色:

use Spatie\Permission\Models\Role;

$role = Role::create(['name' => 'writer']);
新建权限

您可以使用 Permission 类创建新的权限:

use Spatie\Permission\Models\Permission;

$permission = Permission::create(['name' => 'edit articles']);

角色和权限都可以拥有一个或多个用户。为了让用户具有特定的角色或权限,您可以将它们添加到用户模型的 $roles$permissions 属性中:

use App\Models\User;

$user = User::find(1);

$user->assignRole('writer');
$user->givePermissionTo('edit articles');

一旦授权,您可以测试用户是否已被授予特定的角色或权限:

$user->hasRole('writer');
$user->hasPermissionTo('edit articles');
缓存清除

由于缓存机制,一旦用户被分配了新的角色或权限,应用程序可能不会立即反映这些更改。

为了解决这个问题,您可以清除应用程序的缓存以使这些更改生效。

要清除应用程序缓存,请使用 Artisan 命令:

php artisan cache:clear

如果您正在使用 Redis,则可以使用以下命令来清除 Redis 缓存:

php artisan cache:clear redis
总结

现在,您已经知道了如何在 Laravel 中使用 Spatie 权限扩展包,以及如何清除缓存以避免权限变更不生效的问题。

希望这篇文章对您有所帮助!