検索
ホームページバックエンド開発PHPチュートリアルyii2 csrfのローカルスイッチの詳細説明

yii2 csrfのローカルスイッチの詳細説明

Jan 03, 2018 pm 02:27 PM
csrfyii2スイッチ

この記事では主にyii2でCSRF検証を部分的にクローズ(オープン)するサンプルコードを紹介します。編集者がとても良いと思ったので、参考として共有したいと思います。お役に立てれば幸いです。

(1) グローバルに使用する場合は、設定ファイルで直接enableCookieValidationをtrueに設定します

request => [ 
  'enableCookieValidation' => true, 
]

csrfを使用する必要がない場合は、'enableCookieValidation' => falseを設定しますが、これは安全ではないため、yii2のyiiwebrequest EnableCookieValidation はデフォルトで true に設定されています。これは、csrf がデフォルトで有効であることを意味するため、この値を構成してデフォルトで有効にすることもできません。

csrf を有効にすると、グローバルであるため、投稿リクエストに認証が必要になるため、データを投稿するときに、csrf データがフォームで非表示になるように設定する必要があります。

<input type="hidden" name="_csrf" id=&#39;csrf&#39; value="<?= Yii::$app->request->csrfToken ?>">

データを投稿するときは、この値を投稿する必要があります。生成される値は = Yii::$app->request->csrfToken ?> であり、暗号化された csrfToken が返されます。

そのため、投稿フォームであっても、ajax 投稿であっても、csrfToken の値を設定する必要があり、送信時に投稿する必要があります。そうでない場合は、エラーが発生し、認証が通過しません。

(2) 一部のコントローラーで CSRF 検証を使用したくない場合はどうすればよいですか?

方法は非常に簡単で、直接設定します

public $enableCsrfValidation = false ,

このControllerはyiiwebControllerから継承しているので、enableCsrfValidation属性から継承することと同じになります。すると、コントローラインスタンス作成時に、このコントローラではcsrf機能がオフになります。サーバーのポストモードを使用する場合、検証は実行されません。

たとえば、APIを開発するとき、WeChatインターフェイスがインターフェイスにデータを投稿する必要があるとき、WeChatはcsrfTokenを知らないため、投稿データにアクセスするときに、グローバルcsrfがオンになっていると、間違いなく投稿データを投稿できなくなります。無事にアクセスできました。したがって、この API の csrf をオフにする必要があります。

3) 特定のアクションを具体的に閉じたい場合はどうすればよいですか?

一部の関数では、特定のアクションで csrf 検証をオフにする必要がある場合があります。 csrf の検証が beforeAction($Action) で実装されていることがわかりました。次に、Controller の beforeAction($action) メソッドを書き換えます

public function beforeAction($action) { 
 
  $currentaction = $action->id; 
 
  $novalidactions = [&#39;dologin&#39;]; 
 
  if(in_array($currentaction,$novalidactions)) { 
 
    $action->controller->enableCsrfValidation = false; 
  } 
  parent::beforeAction($action); 
 
  return true; 
}

渡されるパラメーター $action は、このアクセスのためにコントローラーによってインスタンス化されたオブジェクトです。多くの情報が含まれているので、印刷して参照してください。

まず $action->id を実行して、現在アクセスされているアクション名を取得します。 $novalidactions は、アクション名を含む配列です。これらのアクションは、CSRF 認証をオフにするために必要なすべての操作 (CSRF 認証をオフにする必要がある操作) です。

現在アクセスされているアクションがこの $novalidactions にあるかどうか。そうであれば、このアクションは csrf 関数をオフにする必要があることを意味するため、コントローラー インスタンスを

$action->controller->enableCsrfValidation = false

に設定してから、parent::beforeAction($ action) を実行します。 )、この時点で、渡された $action のコントローラー インスタンスのenableCsrfValidation が false に変更されています。

最後に true を返す必要があります。そうでない場合、アクション操作は実行されません。

(4) 部分的にオンになっている場合はどうなりますか?

まず、設定ファイルで csrf をグローバルに使用しないように

request => [
&#39;enableCookieValidation&#39; => false,
]

を設定します。

(a) コントローラーで有効にするには、

public $enableCsrfValidation = true

を設定するだけで、コントローラー全体が有効になります

(b) アクションで有効にするには、

public function beforeAction($action) {
$currentaction = $action->id;
$accessactions = [&#39;dologin&#39;];
i f(in_array($currentaction,$accessactions)) {
       $action->controller->enableCsrfValidation = true;
 }

    parent::beforeAction($action);
    return true;
}

$accessactions はアクションの名前ですCSRF を有効にする必要があります。$action->controller->enableCsrfValidation = true に設定すると、現在の操作で csrf を有効にできます。関連する推奨事項: YII フレームワークがカスタム ファイルへの記録ログを実現する方法の詳細な説明

YII フレームワークのバッチ データの簡単な拡張の詳細な説明 認可の検証

以上がyii2 csrfのローカルスイッチの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

PHPの自動装置は何ですか?PHPの自動装置は何ですか?Apr 30, 2025 pm 03:37 PM

PHPでのオートローディングは、必要に応じてクラスファイルを自動的にロードし、メモリの使用を削減し、コード組織を強化することでパフォーマンスを向上させます。ベストプラクティスには、PSR-4の使用とコードを効果的に整理することが含まれます。

PHPストリームとは何ですか?PHPストリームとは何ですか?Apr 30, 2025 pm 03:36 PM

PHPストリームは、一貫したAPIを介したファイル、ネットワークソケット、圧縮形式などのリソースの処理を統合し、複雑さを抽象化し、コードの柔軟性と効率を高めます。

PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?Apr 30, 2025 pm 03:35 PM

この記事では、PHPでファイルアップロードサイズの管理を管理し、2MBのデフォルト制限とPHP.ini設定を変更してそれを増やす方法に焦点を当てています。

PHPのめまいの種類とは何ですか?PHPのめまいの種類とは何ですか?Apr 30, 2025 pm 03:34 PM

この記事では、PHP 7.1で導入されたPHPのヌル可能なタイプについて説明し、変数またはパラメーターが指定されたタイプまたはnullのいずれかを可能にします。読みやすさの改善、タイプの安全性、明示的な意図などの利点を強調し、宣言する方法を説明します

unset()とlink()関数の違いは何ですか?unset()とlink()関数の違いは何ですか?Apr 30, 2025 pm 03:33 PM

この記事では、プログラミングのunset()とlink()関数の違いについて説明し、目的とユースケースに焦点を当てています。 unset()はメモリから変数を削除しますが、link()はファイルシステムからファイルを削除します。どちらもEFFECにとって重要です

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 中国語版

SublimeText3 中国語版

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール