バッファーオーバーフロー攻撃

読み:バッファーオーバーフローこうげき
外語:buffer overflow attack 英語
品詞:名詞

自動変数としてスタック上に取られるデータ領域に、その大きさを越えたデータを入力して任意のコードを実行させる攻撃。

目次

これによってスタック上にあるリターンアドレスを上書きし、入力されたデータ中に含まれる任意のコードを実行させることができる。

ユーザー入力に対して、サイズをチェックしていないstrcat、strcpyなどがターゲットとなる。

(メモリーマップ)
 ← メモリー下位                      メモリー上位 →
┌─────────┬───────┬───────┐
│                  │ 自動変数 ... │<return addr.>│
└─────────┴───────┴───────┘
 ← スタックの成長方向
  
(入力するデータ)
┌────────┬───────┬──┬─────┐
│NOP NOP ...  NOP│<exploit code>│ ...│<address*>│
└────────┴───────┴──┴─────┘

<address*> が正規の <return address> を上書きし、関数が終了した後にexploit codeを実行するようになる。

ただし<address*>に与える正確な値を導き出すのは難しいので、<exploit code>に複数のNOPを前置して<exploit code>に当たる確率を増やす。

コメントなどを投稿するフォームは、日本語対応時のみ表示されます


KisoDic通信用語の基礎知識検索システム WDIC Explorer Version 7.04a (27-May-2022)
Search System : Copyright © Mirai corporation
Dictionary : Copyright © WDIC Creators club