検索
ホームページウェブフロントエンドhtmlチュートリアルCSRFとは何ですか? CSRF の危険性とそれに対する防御方法

この記事の内容は、CSRF とは何ですか? CSRFの危険性と防御方法については、参考にしていただければ幸いです。

CSRF とは

CSRF を理解する前に、2 つの前提条件を普及する必要があります。まず、ログイン権限を確認する方法は現在、ほとんどの Web サイトで使用されています。 セッションセッションタスクモード。簡単に言えば、セッションのメカニズムは、サーバーがキーと値のペアを使用してログイン情報を記録し、同時にセッションが Cookie に保存されることです。 ID (先ほど述べたキー) は Cookie に保存されます。さらに、ブラウザでの HTTP(s) リクエストにより Cookie が自動的に保存されることもわかっています。 サーバーに渡されました。このようにして、各リクエスト中に Cookie を介してセッション ID が取得され、それを介してサーバーからログイン情報が取得され、ユーザー権限の検証が完了します。

もともとこれも良い機能でした。しかし、そのせいで ユーザーが Web サイト A にログインし、Web サイト B にアクセスしたときに A Cookie を送信すると、Cookie は実際にオープンになります。 Web サイト リクエスト。このリクエストには実際に Web サイト A 上のユーザーのログイン情報が含まれます。このときAがB駅にいたら Web サイトのリクエストがユーザーに知られていない場合、それは非常に深刻な損害となります。上記のプロセスはクロスサイト リクエスト攻撃、つまりクロスサイト リクエスト フォージェリです。 CSRF。

CSRF の危険性

CSRF の脆弱性を簡単にまとめると、Web サイトの権限検証の脆弱性を利用して、ユーザーが気づかないうちにリクエストを送信し、ユーザーを「偽装」するというものです。 。 目的。攻撃者が CSRF を使用して実行する主な攻撃の種類は次のとおりです。

攻撃者は、被害者ユーザーをだまして、アカウント詳細の更新、ショッピングの完了、ログアウトなど、被害者が許可したステータス変更操作を完了させることができます。 、さらにはログインやその他の操作も可能です。

ユーザーの個人データを取得します。

他の脆弱性攻撃と連携します。

CSRF ワーム

彼ら CSRF ワームは、その名前が示すとおり、ワーム効果を生み出し、 攻撃は 1 から 10、10 から 100 に広がります。たとえば、コミュニティ内の友人に個人的にメッセージを送信するためのインターフェイスと友人リストを取得するためのインターフェイスには両方とも CSRF 脆弱性があり、攻撃者はそれらを組み合わせて CSRF ワームを作成することができます。ユーザーが悪意のあるページにアクセスすると、ユーザーは次の方法で友人リスト情報を取得します。 CSRF を使用する プライベート メッセージングを行う友人の CSRF 脆弱性により、悪意のあるページを指すメッセージが各友人に送信され、誰かがこのメッセージ内のリンクを閲覧している限り、CSRF ワームは広がり続け、被害と影響が及ぶ可能性があります。原因は大きいです!

防御方法

上記の説明から、CSRF には Cookie を自動的に運ぶ機能とクロスサイト攻撃という 2 つの特徴があることがわかります。これら 2 つの機能に対して次のソリューションを使用できます。

Referer フィールドを確認する

HTTP ヘッダーに Referer フィールドがあることは誰もが知っています。このフィールドは、リクエストの送信元のアドレスを示すために使用されます。 Web サイト内のリクエストのこのフィールドを確認することで、リクエストがこのサイトから発行されたものであるかどうかを知ることができます。このサイトが発行したもの以外のリクエストはすべて拒否できるため、CSRF のクロスサイト特性を回避できます。

const { parse } = require('url');module.exports = class extends think.Logic {
  indexAction() {
    const referrer = this.ctx.referrer();
    const {host: referrerHost} = parse(referrer);
    if(referrerHost !== 'xxx') {
        return this.fail('REFERRER_ERROR');
    }
  }}

これもThinkJSを例にしてLogicで簡単に判断してみます。この方法は、クライアントがリファラーを構築できないことを利用したもので、簡単ではありますが、Web サイトに複数のドメイン名がある場合や、ドメイン名が頻繁に変更される場合には非常に面倒であり、制限もあります。

トークン検証

CSRF はブラウザの Cookie を自動的に渡す機能を利用するため、もう 1 つの防御策は、Cookie を通じて検証情報を渡さず、検証のためにランダムな暗号化された文字列を他のパラメータに追加することです。 。 テスト。ここには 2 つの方法があります:

ランダムな文字列: 各送信にランダムな文字列パラメーターを追加します。パラメーターは、サーバーによって要求されるたびに送信パラメーターに追加されます。 pass パラメータが一貫しているかどうかを検証して、それがユーザー要求であるかどうかを判断します。 CSRF 攻撃の攻撃者はランダム文字列の値を事前に知る方法がないため、サーバーは値を確認することでリクエストを拒否できます。

JWT: 実は例外です セッション ログインに加えて、JWT トークン ログイン検証もますます一般的になりつつあります。このメソッドは、フロントエンドでログイン トークンを記録し、リクエストが行われるたびにヘッダーでそれを渡します。 ログイン検証プロセスは、認証ヘッダーを追加することで実装されます。 CSRF 攻撃では攻撃者はトークンの値を知ることができないため、この方法でも CSRF 攻撃を防ぐことができます。確かに JWT に加えて、トークン ログイン方法には OAuth やその他の多くの方法が含まれます。

以上がCSRFとは何ですか? CSRF の危険性とそれに対する防御方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
HTML、CSS、およびJavaScriptの理解:初心者向けガイドHTML、CSS、およびJavaScriptの理解:初心者向けガイドApr 12, 2025 am 12:02 AM

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割:Webコンテンツの構造HTMLの役割:Webコンテンツの構造Apr 11, 2025 am 12:12 AM

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTMLとコード:用語を詳しく見るHTMLとコード:用語を詳しく見るApr 10, 2025 am 09:28 AM

htmlisaspecifictypeofcodefocuseduructuringwebcontent

HTML、CSS、およびJavaScript:Web開発者に不可欠なツールHTML、CSS、およびJavaScript:Web開発者に不可欠なツールApr 09, 2025 am 12:12 AM

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTML、CSS、およびJavaScriptの役割:コアの責任HTML、CSS、およびJavaScriptの役割:コアの責任Apr 08, 2025 pm 07:05 PM

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは初心者のために簡単に学ぶことができますか?HTMLは初心者のために簡単に学ぶことができますか?Apr 07, 2025 am 12:11 AM

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用​​できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

HTMLでの開始タグの例は何ですか?HTMLでの開始タグの例は何ですか?Apr 06, 2025 am 12:04 AM

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?CSSのフレックスボックスレイアウトを使用して、メニューの点線のラインセグメンテーション効果のセンターアラインメントを実現する方法は?Apr 05, 2025 pm 01:24 PM

メニューで点線のラインセグメンテーション効果を設計する方法は?メニューを設計するときは、通常、皿の名前と価格の間に左右に合わせることは難しくありませんが、真ん中の点線またはポイントはどうですか...

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

AI Hentai Generator

AI Hentai Generator

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

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

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

メモ帳++7.3.1

メモ帳++7.3.1

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン