目次
簡単な例
インターセプターの定義
インターセプターの使用
{{ $post->title }}
ホームページ PHPフレームワーク Laravel Laravel のインターセプター (Gates) について話しましょう

Laravel のインターセプター (Gates) について話しましょう

Sep 28, 2022 pm 07:59 PM
php laravel

Laravel のインターセプター (Gates) について話しましょう

Laravel Gates (インターセプター) を使用すると、ユーザーがアプリケーションの特定の領域にアクセスすることを承認できます。アプリケーションでインターセプタを簡単に定義し、それを使用してアクセスを許可または拒否できます。

簡単な例

ユーザー テーブルに admin という名前の列があるとします。ユーザーが管理者であるかどうかに応じて、次のことができます。 1 または 0 です。次のような簡単なチェックを行うことで、アプリケーションの一部であるモジュールを簡単に保護できます。

Route::get('administration', function(){
    if(auth()->check() && auth()->user()->admin){
        echo 'Welcome to the admin section';
    } else {
        echo 'You shall not pass';
    }
});
ログイン後にコピー

特定のユーザーの admin 行が 1 に設定されている場合、次の出力が表示されます。

Admin access screenshot

そうしないと、次のようなメッセージが表示されます:

Admin denied access

これは素晴らしいですね!アプリケーションの特定の部分へのアクセスを許可または拒否する簡単な方法があります。ただし、問題は、アプリケーション全体でユーザーのアクセス許可を確認および変更する必要がある場所が多数ある場合はどうなるかということです。コードをグローバルに検索し、あらゆる場所でこのロジックを変更する必要があります。あまり効率的ではありません。

このために、ゲート (インターセプター) を定義し、アプリケーション全体でそれを使用できます。

インターセプターの定義

インターセプターを定義するには、App\Providers\AuthServiceProvider.php ファイルを開き、 boot () 次の内容をメソッドに追加します。

public function boot()
{
    $this->registerPolicies();

    Gate::define('access-admin', function ($user) {
        return $user->admin;
    });
}
ログイン後にコピー

このインターセプターは、管理者ユーザーを認証するアプリケーション全体のどこでも使用できます。次のセクションでは、この新しいインターセプターをどのように使用するかを見ていきます。

インターセプターの使用

インターセプターを使用するには、Gate::allows() または Gate::denies( )# を呼び出します。 ## メソッド、以下に示すように:

Route::get('administration', function(){
    if (Gate::allows('access-admin')) {
        echo 'Welcome to the admin section';
    } else {
        echo 'You shall not pass';
    }
});
ログイン後にコピー
注意してください:

Gate::denies() メソッドは Gate::allows() を実行します。逆引きチェック

インターセプタを実行することの利点は、いつでも定義を変更できるようになり、認可ロジックがアプリケーション全体で同期して変更されることです。

インターセプターを使用するもう 1 つの目的は、データに関連するアクセス許可を確認することです。ブログを例に挙げると、ユーザーが作成した投稿に対する編集権限を付与できます。

データをインターセプターに渡して、ユーザーがアクションを実行する権限を持っているかどうかを確認できます。

インターセプターのようにデータを渡す

アプリケーションに

user_id という列を持つ Post テーブルがあるとします。作成したユーザーの ID。次のようにゲート (インターセプター) を定義して、ユーザーが特定の投稿を編集できるかどうかを決定できます。

Gate::define('edit-post', function ($user, $post) {
    return $user->id === $post->user_id;
});
ログイン後にコピー
2 つのパラメーターがインターセプター定義に渡されます。 1 つ目は認証されたユーザーを含む

$user オブジェクトで、2 つ目のパラメータは $post オブジェクトです。

ヒント: 認証されたユーザーが存在しない場合、インターセプターは false を返します。

インターセプタは、認証されたユーザーが元の作成者であればアクセスを許可しますが、それ以外の場合はアクセスを拒否します。

これは、新しい

edit-post インターセプターの使用方法の簡単な例です。

Route::get('edit/{id}', function($id){

    $post = \App\Model\Post::find($id);

    if( Gate::allows('edit-post', $post) ){
        echo 'You can edit this post';
    } else {
        echo 'You shall not pass';
    }

});
ログイン後にコピー
上の例では

Route Closures を使用しましたが、このルートをコントローラーにマップすることもできます。これにより、新しい Authorize 関数も使用できるようになります。

認可認可ヘルパー関数

効率性に加えて、インターセプタを使用するもう 1 つの理由はヘルパー関数です。

ルートをコントローラーにマップするとします。

Route::get('edit/{id}', 'PostController@edit');
ログイン後にコピー

authorize() ヘルパーを使用して、認証されたユーザーに投稿を編集する権限があるかどうかを確認できます。

<?php namespace App\Http\Controllers;

use App\Models\Post;
use Illuminate\Http\Request;

class PostController extends Controller
{
    public function edit($id){

        $post = Post::find($id);
        $this->authorize('edit-post', $post);

    }
}
ログイン後にコピー
コントローラーが

App\Http\Controllers\Controller 基本クラスから継承している場合は、Gate::allow()## と同じように 関数を使用できます。 # function authorize() ヘルパー関数。 最後に、ビューで承認を確認したい場合はどうすればよいでしょうか?これは、

@can

Blade 関数ヘルパーを使用して行うことができます。

ビュー層での認証

ブレード ビューが次のようになっていると仮定します。

nbsp;html>


    <meta>
    <meta>
    <title>{{ $post->title }}</title>


    <h1 id="post-gt-title">{{ $post->title }}</h1>
    <p>{!! $post->body !!}</p>

ログイン後にコピー

ブレード ヘルパー関数を使用できます

@ can

現在のユーザーがこの投稿の編集を許可されているかどうかを確認します: <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">nbsp;html&gt;     &lt;meta&gt;     &lt;meta&gt;     &lt;title&gt;{{ $post-&gt;title }}&lt;/title&gt;     &lt;h1 id=&quot;post-gt-title&quot;&gt;{{ $post-&gt;title }}&lt;/h1&gt;     &lt;p&gt;{!! $post-&gt;body !!}&lt;/p&gt;     @can('edit-post', $post)         <a>id }}">Edit Post</a>     @endcan </pre><div class="contentsignin">ログイン後にコピー</div></div> 認証されたユーザーが投稿の元の作成者である場合、「

投稿の編集

」ボタンが表示されます。

@can

ヘルパー関数を使用すると、コードの読み取りと管理が容易になります。 @cannot を使用して操作を元に戻すこともできます。

概要

これは、Laravel アプリケーションでのゲート (インターセプター) の使用の基本です。インターセプターを使用すると、特定のユーザーがアプリケーションの領域にアクセスすることを簡単に承認できます。これは、オブジェクトに関連付けられた権限のリストであるアクセス制御リスト (ACL) とも呼ばれます。

しかし、物事を複雑にしすぎないでください... 最も単純なシナリオでは、アクセスを許可または拒否するために Interceptors が使用されます。ユーザーは、認可を許可されることも拒否されることもできます。

このチュートリアルは、ユーザーに理解してもらうことではなく、理解してもらうことを目的としているため、ロード オブ ザ リングのガンダルフの画像 (手動の犬の頭) を送信するのは理にかなっています。

Laravel のインターセプター (Gates) について話しましょう

Laravel Gates (インターセプター) の詳細については、必ず Larav 認証ドキュメントを参照してください。

英語のオリジナルアドレス: https://devdojo.com/tnylea/laravel-gates

翻訳アドレス: https://learnku.com/laravel/t/67585

[関連する推奨事項: laravel ビデオチュートリアル]

以上がLaravel のインターセプター (Gates) について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

今まで知らなかったことを後悔している 7 つの PHP 関数 今まで知らなかったことを後悔している 7 つの PHP 関数 Nov 13, 2024 am 09:42 AM

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

Laravelでは、検証コードが電子メールで送信できない状況に対処する方法は? Laravelでは、検証コードが電子メールで送信できない状況に対処する方法は? Mar 31, 2025 pm 11:48 PM

Laravelの電子メールの検証コードの送信の障害を処理する方法は、Laravelを使用することです...

See all articles