Laravel でのユーザー管理と権限制御: 複数のユーザーとロールの割り当ての実装

WBOY
リリース: 2023-08-12 14:57:06
オリジナル
1111 人が閲覧しました

Laravel でのユーザー管理と権限制御: 複数のユーザーとロールの割り当ての実装

Laravel でのユーザー管理と権限制御: 複数のユーザーとロールの割り当ての実装

はじめに:

最新の Web アプリケーションでは、ユーザーの管理と権限制御は非常に重要な機能の 1 つです。 Laravel は、人気のある PHP フレームワークとして、複数のユーザーの権限制御とロールの割り当てを実装するための強力で柔軟なツールを提供します。この記事では、Laravel でユーザー管理および権限制御機能を実装する方法と、関連するコード例を紹介します。

1. インストールと設定

まず、Laravel にユーザー管理と権限制御機能を実装するには、Laravel Breeze と Spatie Laravel Permission の 2 つのパッケージをインストールして設定する必要があります。

1.1 Laravel Breeze のインストール

Laravel Breeze は、ユーザー登録、ログイン、ログアウト、その他の機能を迅速に構築するのに役立つ軽量の認証システムです。まず、コマンドラインで次のコマンドを実行して Laravel Breeze をインストールします。

composer require laravel/breeze --dev
ログイン後にコピー

次に、次のコマンドを実行して Laravel Breeze をインストールおよび設定します。

php artisan breeze:install
npm install
npm run dev
ログイン後にコピー

1.2 Spatie Laravel のインストール権限

Spatie Laravel Permission は、ユーザー権限を管理するためのパッケージです。これは、ロール承認および権限管理機能の実装に役立ちます。次のコマンドを実行して、Spatie Laravel Permission をインストールします:

composer require spatie/laravel-permission
php artisan vendor:publish --provider="SpatiePermissionPermissionServiceProvider"
php artisan migrate
ログイン後にコピー

2. ユーザー管理

2.1 ユーザー モデルと移行の作成

まず、コマンド ラインで次のコマンドを実行して、ユーザー モデルとデータベース移行ファイルを作成します:

php artisan make:model User -m
ログイン後にコピー

次に、生成されたユーザー モデル ファイルに次のコードを追加します:

use IlluminateFoundationAuthUser as Authenticatable;
use SpatiePermissionTraitsHasRoles;

class User extends Authenticatable
{
    use HasRoles;
    
    // 其他代码...
}
ログイン後にコピー

次に、生成されたデータベース移行ファイルに次のコードを追加しますユーザーテーブルのフィールドを定義します:

public function up()
{
    Schema::create('users', function (Blueprint $table) {
        $table->id();
        $table->string('name');
        $table->string('email')->unique();
        $table->timestamp('email_verified_at')->nullable();
        $table->string('password');
        $table->rememberToken();
        $table->timestamps();
    });
}
ログイン後にコピー

最後に、次のコマンドを実行してデータベース移行を実行します:

php artisan migrate
ログイン後にコピー

2.2 登録とログイン

Laravel Breeze が登録を提供してくれました。およびログイン関数の場合は、対応するビュー ファイルでそれらを参照するだけで済みます。 resource/views/auth ディレクトリで register.blade.php ファイルを開き、次のコードを追加します:

<x-guest-layout>
    <x-auth-card>
        <x-slot name="logo">
            <a href="/">
                <x-application-logo class="w-20 h-20 fill-current text-gray-500" />
            </a>
        </x-slot>

        <div class="mb-4 text-sm text-gray-600">
            {{ __('This is a secure area of the application. Please confirm your password before continuing.') }}
        </div>

        <!-- 用户注册代码 -->

    </x-auth-card>
</x-guest-layout>
ログイン後にコピー

次に、login.blade.php ファイルに次のコードを追加します:

<x-guest-layout>
    <x-auth-card>
        <x-slot name="logo">
            <a href="/">
                <x-application-logo class="w-20 h-20 fill-current text-gray-500" />
            </a>
        </x-slot>

        <!-- 用户登录代码 -->

    </x-auth-card>
</x-guest-layout>
ログイン後にコピー

ここまでで、ユーザー登録とログイン機能が完了しました。

3. ロールと権限の制御

3.1 ロールと権限のモデルの作成

まず、コマンド ラインで次のコマンドを実行して、ロールと権限のモデルを作成します。 #

php artisan make:model Role
php artisan make:model Permission
ログイン後にコピー

次に、生成されたロール モデル ファイルに次のコードを追加します。

use SpatiePermissionModelsRole as BaseRole;

class Role extends BaseRole
{
    // 其他代码...
}
ログイン後にコピー

次に、生成されたアクセス許可モデル ファイルにも次のコードを追加します。

use SpatiePermissionModelsPermission as BasePermission;

class Permission extends BasePermission
{
    // 其他代码...
}
ログイン後にコピー

3.2 Assignロールと権限

ロールと権限をユーザーに割り当てるには、ユーザー コントローラーの対応するメソッドにコードを記述する必要があります。 app/Http/Controllers/Auth ディレクトリで RegisteredUserController.php ファイルを開き、store メソッドに次のコードを追加します。

// 创建用户
$user = User::create([
    'name' => $request->name,
    'email' => $request->email,
    'password' => Hash::make($request->password),
]);

// 角色和权限分配示例
$user->assignRole('writer');
$user->givePermissionTo('create articles');
ログイン後にコピー

上記のコードでは、assignRole メソッドと givePermissionTo メソッドを使用してユーザーを割り当てます。 . 役割と権限。

4. 権限制御にミドルウェアを使用する

Laravel では、権限制御にミドルウェアを使用できます。まず、app/Http/Kernel.php ファイルで、Spatie Laravel が提供するミドルウェアを登録します。権限:

protected $routeMiddleware = [
    // 其他中间件...
    'role' => SpatiePermissionMiddlewaresRoleMiddleware::class,
    'permission' => SpatiePermissionMiddlewaresPermissionMiddleware::class,
];
ログイン後にコピー

次に、対応するルートでミドルウェアを使用してユーザー アクセスを制限します:

Route::middleware(['permission:create articles'])->group(function () {
    // 允许拥有'create articles'权限的用户访问的路由
});
ログイン後にコピー
こうすることで、「記事の作成」権限を持つユーザーのみがルートにアクセスできるようになります。

概要:

この記事では、Laravel でユーザー管理と権限制御を実装する方法を紹介します。 Laravel BreezeやSpatie Laravel Permissionなどのコンポーネントを利用することで、ユーザー登録、ログイン、ロール権限制御機能を迅速に構築できます。この記事が、複数のユーザーの権限制御とロールの割り当てを実装する際に皆様のお役に立てれば幸いです。

以上がLaravel でのユーザー管理と権限制御: 複数のユーザーとロールの割り当ての実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!