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
に設定されている場合、次の出力が表示されます。
そうしないと、次のようなメッセージが表示されます:
これは素晴らしいですね!アプリケーションの特定の部分へのアクセスを許可または拒否する簡単な方法があります。ただし、問題は、アプリケーション全体でユーザーのアクセス許可を確認および変更する必要がある場所が多数ある場合はどうなるかということです。コードをグローバルに検索し、あらゆる場所でこのロジックを変更する必要があります。あまり効率的ではありません。
このために、ゲート (インターセプター) を定義し、アプリケーション全体でそれを使用できます。
インターセプターの定義
インターセプターを定義するには、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'; } });
注意してください:インターセプタを実行することの利点は、いつでも定義を変更できるようになり、認可ロジックがアプリケーション全体で同期して変更されることです。 インターセプターを使用するもう 1 つの目的は、データに関連するアクセス許可を確認することです。ブログを例に挙げると、ユーザーが作成した投稿に対する編集権限を付与できます。 データをインターセプターに渡して、ユーザーがアクションを実行する権限を持っているかどうかを確認できます。Gate::denies()
メソッドは
Gate::allows()を実行します。逆引きチェック
インターセプターのようにデータを渡す
アプリケーションにuser_id という列を持つ Post テーブルがあるとします。作成したユーザーの
ID。次のようにゲート (インターセプター) を定義して、ユーザーが特定の投稿を編集できるかどうかを決定できます。
Gate::define('edit-post', function ($user, $post) { return $user->id === $post->user_id; });
$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()
ヘルパー関数。 最後に、ビューで承認を確認したい場合はどうすればよいでしょうか?これは、
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>
<meta>
<meta>
<title>{{ $post->title }}</title>
<h1 id="post-gt-title">{{ $post->title }}</h1>
<p>{!! $post->body !!}</p>
@can('edit-post', $post)
<a>id }}">Edit Post</a>
@endcan
</pre><div class="contentsignin">ログイン後にコピー</div></div>
認証されたユーザーが投稿の元の作成者である場合、「
」ボタンが表示されます。
@can ヘルパー関数を使用すると、コードの読み取りと管理が容易になります。 @cannot
を使用して操作を元に戻すこともできます。
これは、Laravel アプリケーションでのゲート (インターセプター) の使用の基本です。インターセプターを使用すると、特定のユーザーがアプリケーションの領域にアクセスすることを簡単に承認できます。これは、オブジェクトに関連付けられた権限のリストであるアクセス制御リスト (ACL) とも呼ばれます。
しかし、物事を複雑にしすぎないでください... 最も単純なシナリオでは、アクセスを許可または拒否するために Interceptors が使用されます。ユーザーは、認可を許可されることも拒否されることもできます。
このチュートリアルは、ユーザーに理解してもらうことではなく、理解してもらうことを目的としているため、ロード オブ ザ リングのガンダルフの画像 (手動の犬の頭) を送信するのは理にかなっています。
Laravel Gates (インターセプター) の詳細については、必ず Larav 認証ドキュメントを参照してください。
英語のオリジナルアドレス: https://devdojo.com/tnylea/laravel-gates
翻訳アドレス: https://learnku.com/laravel/t/67585
[関連する推奨事項: laravel ビデオチュートリアル]
以上がLaravel のインターセプター (Gates) について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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