前回の例では、ミドルウェアの定義を学び、ミドルウェアの意味を理解した後、マニュアルをめくってみると、「プレミドルウェア」と「ポストミドルウェア」という別のマニュアルが見つかりました。両者の違いは何ですか?
1. 定義の違い。
プレミドルウェアとポストミドルウェアの定義が異なることは、公式サイトのマニュアルを見れば容易にわかりますので、以下に見てみましょう。
ミドルウェア以前の定義:
<?php namespace app\middleware; class Before { public function handle($request, \Closure $next) { // 添加中间件执行代码 return $next($request); } }
ミドルウェア以降:
<?php namespace app\middleware; class After { public function handle($request, \Closure $next) { $response = $next($request); // 添加中间件执行代码 return $response; } }
詳しく見てみると、最終的には、この 2 つは実行コードと $next であることがわかりました。 ($request) 順序の問題、プレミドルウェアとポストミドルウェアの鍵となるのはこの順序です。
2. $request は異なります。
次のコードをプレミドルウェアとポストミドルウェアでそれぞれ出力できます。
halt($request);
慎重に比較したところ、プレミドルウェアのコントローラーとメソッドが同じであることがわかりました。ミドルウェアが空の場合、ポストミドルウェアはコントローラー名とメソッドを取得できます。したがって、現在アクセスされているコントローラーとメソッドを取得したい場合は、ポストミドルウェアを使用して解決する必要があります。
#3. ミドルウェアがログイン シナリオを傍受します。
まず、公式 Web サイトでミドルウェアの定義を見てみましょう:ミドルウェアは主に、アプリケーションの HTTP リクエストをインターセプトまたはフィルターし、実行するために使用されます。必要な事務処理を行います。公式 Web サイトの定義を見て、友人はログイン傍受にはミドルウェアを使用するのが本当に最善であると考えるかもしれません。しかし、プレミドルウェアを使用すべきでしょうか、それともポストミドルウェアを使用すべきでしょうか?
<?php namespace app\middleware; class After { public function handle($request, \Closure $next) { $response = $next($request); // 添加中间件执行代码 if(empty('session')){ echo '登录不合法'; //跳转到登录页面 } return $response; } }バックエンド ホーム ページ:
public function index(){ echo '后台首页'; }実行結果から、ログイン ジャンプ前でもインデックス メソッドを実行でき、コンテンツを出力できることがわかります。 したがって、ポストミドルウェアはログインシナリオでは使用できません。ログインを傍受するにはプレミドルウェアが最適です。このとき、現在のアクセスがログインであるかどうかも判断する必要があります。ログインの場合は、 、多くのリダイレクトが発生するため、友人はこれを適切に処理する必要があります。 上記はプレミドルウェアとポストミドルウェアの紹介ですが、実際のプロジェクトでは、実際のビジネスロジックに基づいてプレミドルウェアを使用するかポストミドルウェアを使用するかを決定します。
以上がThinkPHP6 のフロントエンドミドルウェアとバックエンドミドルウェアの違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、LenovoのThinkbookとThinkPadラップトップのラインを比較します。 ThinkPadsは、専門家の耐久性とパフォーマンスを優先しますが、ThinkBooksは毎日の使用にスタイリッシュで手頃な価格のオプションを提供します。 重要な違いは、ビルド品質にあります

この記事では、ThinkPhpアプリケーションでのSQL注入を防ぐ方法について説明します。 ThinkPhpのクエリビルダーを介してパラメーター化されたクエリを使用し、直接SQLの連結を避け、堅牢な入力検証と消毒を実装することを強調しています。 広告

この記事では、パッチング、予防、および監視を強調し、ThinkPhpの脆弱性について説明します。 更新、セキュリティパッチ、およびコード修正を介して特定の脆弱性の処理を詳述します。 安全な構成、入力などのプロアクティブな測定

この記事では、ThinkPhpソフトウェアのインストールを詳しく説明し、ダウンロード、抽出、データベースの構成、許可確認などの手順をカバーしています。 システム要件(PHPバージョン、Webサーバー、データベース、拡張機能)に対応し、共通インストール

このチュートリアルは、一般的なThinkPHPの脆弱性に対応しています。 定期的な更新、セキュリティスキャナー(RIP、Sonarqube、Snyk)、手動コードレビュー、および識別と修復のための浸透テストを強調しています。 予防措置には安全が含まれます

この記事では、ThinkPhpのCLI機能を使用して、構築コマンドラインアプリケーション(CLI)を示しています。 INSUなどの一般的な落とし穴を強調しながら、モジュラー設計、依存関係注入、堅牢なエラー処理などのベストプラクティスを強調しています

このガイドは、database.phpを介した構成に焦点を当てたthinkphpのデータベース接続を詳しく説明しています。 PDOを使用し、ORMまたは直接SQL相互作用を可能にします。 ガイドは、共通の接続エラーのトラブルシューティング、複数の接続の管理、ENをカバーしています

この記事では、無料のオープンソースPHPフレームワークであるThinkPhpを紹介します。 ThinkPHPのMVCアーキテクチャ、機能(ルーティング、データベースインタラクション)、利点(迅速な発展、使いやすさ)、および短所(潜在的な過剰エンジニアリング、コミュニケーション)の詳細


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

Dreamweaver Mac版
ビジュアル Web 開発ツール
