国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
アンチCSRFトークンを生成して保存します
フォームの提出でトークンを検証します
AjaxリクエストとAPIを忘れないでください
ボーナスのヒント:Samesite CookieとHTTPのみのフォーム
ホームページ バックエンド開発 PHPチュートリアル PHPでのクロスサイトリクエスト偽造(CSRF)攻撃を防ぐにはどうすればよいですか?

PHPでのクロスサイトリクエスト偽造(CSRF)攻撃を防ぐにはどうすればよいですか?

Jun 28, 2025 am 02:25 AM
php csrf

PHPでのCSRF攻撃を防ぐには、抗CSRFトークンを?qū)g裝します。 1)random_bytes()またはbin2hex(random_bytes(32))を使用して安全なトークンを生成して保存し、$ _sessionで保存し、隠された入力としてフォームに含めます。 2)ポストトークンをセッションで保存されたものと厳密に比較することにより、トークンを提出時に検証します。 403エラーで不一致のリクエストを拒否します。 3)ヘッダーまたはボディにトークンを含めることにより、AJAX/APIリクエストを保護(hù)します。多くの場合、メタタグから取得します。 4)トークンを出力するときにhtmlspecialchars()を使用して、XSS漏れを防ぎます。 5)ログインのような重要なアクションの後にトークンを再生します。 6)セッションCookieのSAMESITE = STRICT/LAXを設(shè)定し、狀態(tài)の変更の取得を避けます。 7)機(jī)密アクションについてユーザーを再認(rèn)証します。これらの手順により、セキュリティの完全性を維持しながら、すべての要求タイプにわたって包括的なCSRF保護(hù)が保証されます。

PHPでのクロスサイトリクエスト偽造(CSRF)攻撃を防ぐにはどうすればよいですか?

PHPでのCSRF攻撃を防ぐには、主にトークンを使用して、強(qiáng)固な抗CSRF戦略を?qū)g裝する必要があります。アイデアは簡単です。すべての狀態(tài)を変えるリクエスト(フォーム提出など)には、正當(dāng)なユーザーだけが知っている獨自の予測不可能なトークンを含める必要があります。このトークンがなければ、サーバーはリクエストを処理してはなりません。

実際に実際にうまくやる方法は次のとおりです。


アンチCSRFトークンを生成して保存します

アクションを?qū)g行するフォームを表示するたびに(設(shè)定を送信したり購入したりするなど)、安全なトークンを生成し、セッションのようにサーバー側(cè)の安全な場所に保存します。

  • random_bytes()またはbin2hex(random_bytes(32))を使用して、強(qiáng)いトークンを作成します。
  • フォームが送信されたら後で比較できるように、 $_SESSIONで保存します。

例えば:

 if(empty($ _ session ['csrf_token'])){
    $ _Session ['csrf_token'] = bin2hex(random_bytes(50));
}

それからあなたのフォームで:

 <入力型= "hidden" name = "csrf_token" value = "<?= htmlspecialchars($ _ session [&#39;csrf_token&#39;])?>">

このように、各フォームの提出には、攻撃者が推測または再現(xiàn)できないトークンが含まれています。


フォームの提出でトークンを検証します

フォームが送信されたら、ポストデータのトークンがセッションに保存されているものと一致するかどうかを確認(rèn)します。

  • 常にトークンの存在を確認(rèn)してください。
  • タイプジャグリングの問題を避けるために、それを厳密に( === )比較してください。
  • 一致しない場合は、403エラーなどでリクエストを拒否します。

例コード:

 if(!isset($ _ post [&#39;csrf_token&#39;])|| $ _post [&#39;csrf_token&#39;]!== $ _session [&#39;csrf_token&#39;]){
    http_response_code(403);
    die( &#39;無効なcsrfトークン。&#39;);
}

小さいながらも重要な詳細(xì):トークンをHTMLに出力するときは、XSSがトークンの漏れを防ぐときは、常にhtmlspecialchars()を使用してください。

また、ログインやパスワードの変更などの重要なアクションの後、トークンを回転または再生することを忘れないでください。


AjaxリクエストとAPIを忘れないでください

サイトがJavaScriptを使用してフォームを送信したり、API呼び出しを行ったりする場合、これらのリクエストにはCSRF保護(hù)も必要です。

  • AJAXリクエストのヘッダーまたはボディにCSRFトークンを含めます。
  • トークンをメタタグまたはインラインスクリプトに保存し、電話をかけるときにそこから読むことができます。

たとえば、HTMLヘッドにメタタグを設(shè)定します。

 <meta name = "csrf-token" content = "<?= htmlspecialchars($ _ session [&#39;csrf_token&#39;])?>">

それからあなたのJSで:

 fetch( &#39;/update-profile&#39;、{
    方法:「投稿」、
    ヘッダー:{
        &#39;x-csrf-token&#39;:document.queryselector( &#39;meta [name = "csrf-token"]&#39;)。コンテンツ
    }、
    ボディ:新しいurlsearchparams({name: &#39;John Doe&#39;})
});

バックエンドで、 X-CSRF-Tokenヘッダーのトークンを探して、通常のフォームと同じように検証します。

注意すべきことの1つは、PHPバックエンドに通知する?yún)g一ページアプリ(SPA)またはモバイルアプリを構(gòu)築する場合は、より良い保護(hù)のために同じサイトCookieとCSRFトークンを一緒に使用することを検討してください。


ボーナスのヒント:Samesite CookieとHTTPのみのフォーム

トークンがあっても、あなたがとることができる余分な手順があります:

  • セッションクッキーにSameSite=StrictまたはLaxを設(shè)定して、クロスオリジンリクエストを減らします。
  • フォームが必要な場合にのみPOSTリクエストを受け入れることを確認(rèn)してください。GETベースの狀態(tài)の変更を許可しないでください。
  • 機(jī)密操作(アカウントの削除など)の場合、再認(rèn)証は別のレイヤーを追加するのに役立ちます。

これらはCSRFトークンの代替品ではありませんが、それらと一緒にうまく機(jī)能します。


それは基本的にそれです。 PHPのCSRF保護(hù)は、優(yōu)れたトークンの生成、それらを適切に検証し、関連するすべてのリクエストに含まれていることを確認(rèn)することになります。それは過度に複雑ではありませんが、1つのステップをスキップすると混亂するのは簡単です。

以上がPHPでのクロスサイトリクエスト偽造(CSRF)攻撃を防ぐにはどうすればよいですか?の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中國語版

SublimeText3 中國語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

2つのPHPアレイを組み合わせる方法ユニークな値は? 2つのPHPアレイを組み合わせる方法ユニークな値は? Jul 02, 2025 pm 05:18 PM

2つのPHPアレイをマージし、一意の値を保持するには、2つの主要な方法があります。 1.インデックスアレイまたは重複排除のみの場合、array_mergeとarray_uniqueの組み合わせを使用します:最初のマージArray_merge($ array1、$ array2)を使用してから、array_unique()を使用して、最終的にすべての一意の値を含む新しいアレイを取得します。 2。関連アレイと最初の配列のキー値のペアを保持したい場合は、演算子を使用してください。$ result = $ array1 $ array2。これらの2つの方法は、キー名が保持されているか焦點があるかに応じて、異なるシナリオに適用できます。

PHP出口機(jī)能の使用方法は? PHP出口機(jī)能の使用方法は? Jul 03, 2025 am 02:15 AM

Exit()は、すぐにスクリプトの実行を終了するために使用されるPHPの関數(shù)です。一般的な用途には次のものが含まれます。1。ファイルが存在しない、または検証が失敗するなど、例外が検出されたときにスクリプトを事前に終了します。 2。デバッグ中の出力中間結(jié)果と実行を停止します。 3。Header()と組み合わせてリダイレクトした後、Exit()を呼び出して、後続のコード実行を防ぎます。さらに、exit()は、文字列パラメーターを出力コンテンツまたはステータスコードとして整數(shù)として受け入れることができ、そのエイリアスはdie()です。

HTMLで記事、セクション、および脇にセマンティック構(gòu)造を適用する HTMLで記事、セクション、および脇にセマンティック構(gòu)造を適用する Jul 05, 2025 am 02:03 AM

HTMLでのセマンティックタグの合理的な使用は、ページ構(gòu)造の明確さ、アクセシビリティ、SEO効果を改善することができます。 1.ブログの投稿やコメントなどの獨立したコンテンツブロックに使用されると、自己完結(jié)型でなければなりません。 2。通常はタイトルを含む分類関連のコンテンツに使用され、ページのさまざまなモジュールに適しています。 3。サイドバーの推奨事項や著者プロファイルなど、メインコンテンツに関連する補(bǔ)助情報に使用されますが、コアではありません。実際の開発では、ラベルを組み合わせて、その他を組み合わせ、過度のネストを避け、構(gòu)造をシンプルに保ち、開発者ツールを使用して構(gòu)造の合理性を検証する必要があります。

要求された操作には、標(biāo)高ウィンドウが必要です 要求された操作には、標(biāo)高ウィンドウが必要です Jul 04, 2025 am 02:58 AM

「この操作は権限のエスカレーションが必要」というプロンプトに遭遇した場合、管理者の権限を継続する必要があることを意味します。ソリューションには以下が含まれます。1。「管理者として実行」プログラムを右クリックするか、ショートカットを設(shè)定して常に管理者として実行します。 2.現(xiàn)在のアカウントが管理者アカウントであるかどうかを確認(rèn)してください。 3.管理者の権限を使用してコマンドプロンプトまたはPowerShellを開き、関連するコマンドを?qū)g行します。 4.ファイルの所有権を取得するか、必要に応じてレジストリを変更することにより制限をバイパスしますが、そのような操作は注意し、リスクを完全に理解する必要があります。許可の身元を確認(rèn)し、上記の方法を試してみると、通常は問題を解決します。

PHPで配列を作成する方法は? PHPで配列を作成する方法は? Jul 02, 2025 pm 05:01 PM

PHPで配列を作成するには、Array()関數(shù)を使用するか、ブラケットを使用する方法は2つあります。 1. Array()関數(shù)を使用することは、適切な互換性を備えた従來の方法です。 $ fruits = array( "apple"、 "banana"、 "orange")などのインデックス配列、および$ user = array( "name" => "john"、 "age" => 25)などの連想配列を定義します。 2。[]を使用することは、$ COLORなどのPHP5.4以降、より簡単なサポート方法です

PHP RAW POSTデータPHP PHP RAW POSTデータPHP Jul 02, 2025 pm 04:51 PM

PHPで生のポストデータを処理する方法は、JSON、XML、またはその他のカスタム形式データの受信に適した$ rawData = file_get_contents( 'php:// input')を使用することです。 1.php://入力は読み取り専用のストリームであり、これは投稿リクエストでのみ有効です。 2.一般的な問題には、サーバー構(gòu)成またはミドルウェアの読み取り入力ストリームが含まれます。これにより、データを取得することができません。 3.アプリケーションシナリオには、フロントエンドのフェッチリクエストの受信、サードパーティのサービスコールバック、およびRestfulapisの構(gòu)築が含まれます。 4. $ _POSTとの違いは、$ _POSTが標(biāo)準(zhǔn)フォームデータを自動的に解析し、元のデータは非標(biāo)準(zhǔn)形式に適しており、手動解析を可能にすることです。 5。通常のHTM

ファイルアップロードをPHPで安全に処理する方法は? ファイルアップロードをPHPで安全に処理する方法は? Jul 08, 2025 am 02:37 AM

PHPファイルのアップロードを安全に処理するには、ソースとタイプを確認(rèn)し、ファイル名とパスを制御し、サーバー制限を設(shè)定し、メディアファイルを2回プロセスする必要があります。 1.トークンを介してCSRFを防ぐためにアップロードソースを確認(rèn)し、ホワイトリストコントロールを使用してFINFO_FILEを介して実際のMIMEタイプを検出します。 2。ファイルをランダムな文字列に変更し、検出タイプに従って非WEBディレクトリに保存する拡張機(jī)能を決定します。 3。PHP構(gòu)成は、アップロードサイズを制限し、一時的なディレクトリnginx/apacheはアップロードディレクトリへのアクセスを禁止します。 4. GDライブラリは寫真を再利用して、潛在的な悪意のあるデータをクリアします。

PHPの參照により、値ごとに変數(shù)をどのように渡しますか? PHPの參照により、値ごとに変數(shù)をどのように渡しますか? Jul 08, 2025 am 02:42 AM

inphp、variablySarepassedByValueByDefault、意味することを意味します

See all articles