ホームページ ウェブフロントエンド jsチュートリアル ノード アプリケーションでタイミング攻撃を使用する場合、どのようなセキュリティ脆弱性が存在しますか?

ノード アプリケーションでタイミング攻撃を使用する場合、どのようなセキュリティ脆弱性が存在しますか?

Jun 02, 2018 pm 05:09 PM
node 存在する

この記事は、原則に基づいてノード アプリケーションのタイミング攻撃セキュリティ脆弱性を分析します。興味のある方は参考として読んでください。

はじめに

プロジェクトで eslint エラー、潜在的なタイミング攻撃が発生した場合は、無視しないでください。これはセキュリティ上の問題、つまりタイミング攻撃です。
eslint エラーの原因

まず、eslint は eslint-plugin-security というプラグインを導入していますが、このプラグインは潜在的なセキュリティ問題を特定するのに役立ちますが、プラグインのソース コード アドレスも原因となります。に付いています。

var keywords = '((' + [
  'password',
  'secret',
  'api',
  'apiKey',
  'token',
  'auth',
  'pass',
  'hash'
 ].join(')|(') + '))';

 var re = new RegExp('^' + keywords + '$', 'im');

 function containsKeyword (node) {
  if (node.type === 'Identifier') {
   if (re.test(node.name)) return true;
  }
  return
 }
 if (node.test.operator === '==' || node.test.operator === '===' || node.test.operator === '!=' || node.test.operator === '!==') {
  // 在这里 console 出错误
 }
ログイン後にコピー

まず、このプラグインは今回の演算子が ==, ===,! であるかどうかを判定します。 =、! ==そのうちの 1 つ、次に識別子 (フィールド名) に特別な文字列パスワード、シークレット、API、APIKey、トークン、認証、パス、ハッシュが含まれているかどうかを確認します。両方の条件が同時に満たされた場合、eslint はコンパイルしてレポートします。エラー 潜在的なタイミング攻撃。

攻撃の定義

タイミング攻撃: サイドチャネル攻撃/サイドチャネル攻撃に属するタイミング攻撃とは、暗号化および復号化されたデータ、データの比較時間、データなどのチャネル外の情報の使用を指します。攻撃方法は「傍観者攻撃」に相当します。

攻撃ポイント

まず、js で 2 つの文字列のサイズを比較する原理について説明します。

  • 文字列の長さが 0 かどうかを判断します。0 の場合は結果を直接比較できます。 、2番目のステップに入ります。

  • 文字列は文字で構成され、各文字の charCode によって比較されます。

  • 2 番目のステップでは、1 文字が異なる限り false を返し、残りの文字は比較されません。

単一文字の比較は非常に高速であり、攻撃者は測定時間の精度をマイクロ秒まで調整し、応答時間の違いからどの文字が使用されていないかを計算することができます。このようにして、何度も実験したり、コードを記述したりできます。 Python でスクリプトを実行すると、正しいパスワードを試すことができ、パスワード解析の難易度も大幅に下がります。

脆弱な書き込み方法

if (user.password === password) {
  return { state: true }; // 登录成功
 }
ログイン後にコピー

防御策

入力が異なると処理時間も異なります。これを防ぐには、入力されたパスワードに関係なく、文字列比較にかかる時間が同じになるようにする必要があります。
攻撃を受けにくい書き込み

システム内の各パスワードの長さは固定されており、パスワードが同じかどうかを比較するたびに、正しいパスワードの長さを比較回数としてXORを使用して比較します。各文字の Unicode エンコードが等しいかどうかを確認し、各比較結果を配列に格納し、最後に配列の各要素が 0 であるかどうかを判断します (0 は 2 つの文字が同じであることを意味します)。

 // psdReceived 为用户输入密码;
 // psdDb 为系统中存储的正确用户密码
 const correctUser = (psdDb, psdReceived) => {
  const state = [];
  for (let i = 0; i < psdDb.length; ++i) {
   if (!psdReceived[i]) {
    state.push(false);
   } else {
    state.push(psdReceived.charCodeAt(i) ^ psdDb.charCodeAt(i));
   }
  }
  return state.length !== 0 && state.every(item => !item);
 }
ログイン後にコピー

スリーパーティパッケージの推奨事項

この問題を解決するには、npm モジュール cryptiles を使用することもできます

import cryptiles from &#39;cryptiles&#39;;

......
return cryptiles.fixedTimeCimparison(passwordFromDb, passwordReceived);
ログイン後にコピー

上記は、私が皆さんのためにまとめたものであり、将来的に皆さんのお役に立てれば幸いです。

関連記事:

NodeJSの親プロセスと子プロセスのリソース共有原理と実装方法

vueで画像とファイルアップロードを実装するサンプルコード

vue axiosフォーム送信画像アップロード例

以上がノード アプリケーションでタイミング攻撃を使用する場合、どのようなセキュリティ脆弱性が存在しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

nvmでノードを削除する方法 nvmでノードを削除する方法 Dec 29, 2022 am 10:07 AM

nvm でノードを削除する方法: 1. 「nvm-setup.zip」をダウンロードして C ドライブにインストールします; 2. 「nvm -v」コマンドで環境変数を構成し、バージョン番号を確認します; 3. 「nvm」を使用しますinstall" コマンド ノードのインストール; 4. "nvm uninstall" コマンドでインストールしたノードを削除します。

Express を使用してノード プロジェクトでファイルのアップロードを処理する方法 Express を使用してノード プロジェクトでファイルのアップロードを処理する方法 Mar 28, 2023 pm 07:28 PM

ファイルのアップロードをどのように処理するか?次の記事では、Express を使用してノード プロジェクトでファイルのアップロードを処理する方法を紹介します。

NodeサービスのDockerミラーリングを行うにはどうすればよいですか?極限最適化の詳しい説明 NodeサービスのDockerミラーリングを行うにはどうすればよいですか?極限最適化の詳しい説明 Oct 19, 2022 pm 07:38 PM

この期間中、私は Tencent ドキュメントのすべてのカテゴリに共通する HTML 動的サービスを開発していましたが、さまざまなカテゴリへのアクセスの生成と展開を容易にし、クラウド移行のトレンドに従うために、Docker を使用して修正することを検討しました。サービス内容や製品バージョンを一元管理します。この記事では、私が Docker を提供するプロセスで蓄積した最適化の経験を参考として共有します。

Nodeのプロセス管理ツール「pm2」を徹底分析 Nodeのプロセス管理ツール「pm2」を徹底分析 Apr 03, 2023 pm 06:02 PM

この記事では、Node のプロセス管理ツール「pm2」について説明し、pm2 が必要な理由、pm2 のインストール方法と使用方法について説明します。皆様のお役に立てれば幸いです。

PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? Mar 05, 2025 pm 05:57 PM

ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

pkg を使用して Node.js プロジェクトを実行可能ファイルにパッケージ化する方法について説明します。 pkg を使用して Node.js プロジェクトを実行可能ファイルにパッケージ化する方法について説明します。 Dec 02, 2022 pm 09:06 PM

Nodejs実行可能ファイルをpkgでパッケージ化するにはどうすればよいですか?次の記事では、pkg を使用して Node プロジェクトを実行可能ファイルにパッケージ化する方法を紹介します。

npm ノード gyp が失敗した場合の対処方法 npm ノード gyp が失敗した場合の対処方法 Dec 29, 2022 pm 02:42 PM

「node-gyp.js」が「Node.js」のバージョンと一致しないため、npm node gyp が失敗します。解決策は次のとおりです: 1. 「npm cache clean -f」を使用してノード キャッシュをクリアします; 2. 「npm install -」を使用します。 g n" n モジュールをインストールします。 3. 「n v12.21.0」コマンドを使用して、「node v12.21.0」バージョンをインストールします。

シングルサインオンシステムとは何ですか? Nodejsを使用して実装するにはどうすればよいですか? シングルサインオンシステムとは何ですか? Nodejsを使用して実装するにはどうすればよいですか? Feb 24, 2023 pm 07:33 PM

シングルサインオンシステムとは何ですか? Nodejsを使用して実装するにはどうすればよいですか?次の記事ではnodeを使ってシングルサインオンシステムを実現する方法を紹介しますので、参考になれば幸いです。

See all articles