Webアプリにおける11の脆弱性の常識と対策
株式会社メセナ・ネットコム
山中 秀樹
2009/9/1
本連載は、JSP/サーブレット+StrutsのWebアプリケーション開発を通じて、Java言語以外(PHPやASP.NET、Ruby on Railsなど)の開発にも通用するWebアプリケーション全般の広い知識・常識を身に付けるための連載です
| 【2013年2月25日】編集部より、おわびと訂正のお知らせ 本稿において読者の皆さまより多数のご指摘をいただきまして、誠にありがとうございます。編集部であらためて調べた結果、間違いを把握し、あらためて修正版を掲載させていただきます。この度は、長期にわたり誤った内容を掲載したので、読者の皆さまに多大なご迷惑をお掛けしたした点をおわび申し上げます。 通常、記事に間違いがあった場合には、筆者確認後に修正版を掲載するのですが、今回の場合、初出時より時間が経過してしまっていたこともあり、筆者と連絡が取れませんでした。今回は影響が大きいこともあり、編集部内で直せる部分については極力対応し、再掲載させていただきました。修正に際しては、本稿にご指摘をいただいた徳丸浩さまにご協力いただきました。徳丸さまには、この場を借りてお礼申し上げます。また、内容について正確を期せずに混乱を招いた点、あらためて読者の皆さまにおわび申し上げます。 |
切っても切れない? Webアプリケーションと脆弱性
あらためて確認しておきますが、Webアプリケーションとは、Webサーバ上で動作するソフトウェアのことです。具体例には、オンラインショッピング・オンラインバンキングなどを指し、私たちユーザーはWebブラウザでこれらのサービスを利用します。
このように、非常に利便性の高いWebアプリケーションでも注意しなければならないことがあります。それは、Webアプリケーションにおけるセキュリティや脆弱性についての問題です。
■ Webアプリは、開発者による脆弱性への対策が必要
脆弱性とは、「脆く、傷つきやすく、攻撃に対して弱い」ことです。ハードウェアの欠陥やソフトウェアのバグ、想定外のオペレーションなどが、これに当たります。
このセキュリティ問題については、Webアプリケーションの脆弱性をついた攻撃はユーザー側の注意では防ぐことができないので、ソフトウェアを提供しているベンダが問題を修復する必要があり、Webアプリケーションでは開発者が、セキュリティについて常に留意し、対策を施す必要があります。
■ Webアプリに対する11の代表的な攻撃手法
一般的なWebサーバのセキュリティ対策というと、ファイアウォールやウイルス対策などがあります。しかし、Webアプリケーションへの攻撃に対しては、これらの対策だけでは不十分です。
Webアプリケーションにおけるセキュリティホールの解説を行う前に、どのような攻撃手法が存在するか簡単に整理しましょう。現在、一般的に知られている代表的な攻撃には、以下のようなものがあります。
| 表 11の代表的な攻撃手法一覧(インデックスになっています) | ||||||||||||||||||||||||
|
これらの攻撃のほとんどが、ファイアウォールなどでは防ぐことができず、アプリケーションレベルで対応しなくてはなりません。今回は、表にある11種類の脆弱性について解説し、その対策を説明します。
【1】XSS(クロスサイトスクリプティング)
XSSとは、悪意のあるスクリプトが訪問者のWebブラウザに混入され、実行されてしまう脆弱性のことです。
例えば、入力した文字を画面に表示させるプログラムがあるとします。このプログラムに適切な入力値チェックが実装されていない場合、悪意のあるスクリプトがWeb画面に埋め込まれてしまい、ユーザーのWebブラウザ上で実行されてしまいます。この結果、セッションの乗っ取りやページの書き換え、強制遷移が可能となるため、フィッシング詐欺や“なりすまし”などの犯罪に利用されます。
一般的にデータベース中の特殊記号や、ユーザーからの入力内容をそのまま表示すると、XSSの脆弱性の原因となります。
■ 対策
対策としては、特殊文字のエスケープや入力データチェックなどが必要です。
編集部注:XSSの対策に関しては、以下の記事もご参考にしていただければと思います
| 適切なエスケープ処理でXSSに備える Strutsで作るセキュアWebアプリケーション(1) JavaでWebアプリを作成するときに、セキュリティで注意すべき点は? 代表的なカスタムタグを分析する 「Security&Trust」フォーラム 2006/3/23 |
||
| サーブレットコンテナが抱える問題を認識する Strutsで作るセキュアWebアプリケーション(2) エラーページの出力が原因となってXSSが引き起こされる可能性がある。サーブレットコンテナに依存しない解決法とは? 「Security&Trust」フォーラム 2006/4/27 |
||
| クロスサイトスクリプティング対策の基本 前編 クロスサイトスクリプティング脆弱性とは? 中編 XSS脆弱性により起こる被害とその対策 後編 XSSを防ぐために不可欠なサニタイジング(無害化) Webアプリケーションに存在するセキュリティホールが問題となっており、その代表格「XSS」の仕組みを解説しよう 「Security&Trust」フォーラム | ||
| mod_securityのXSS対策ルールを作成する Webアプリケーションに潜むセキュリティホール(12) Webアプリケーションファイアウォールの「mod_security」を運用する。まずはXSS対策を施してみよう…… 「Security&Trust」フォーラム 2004/9/16 |
||
| XSSは知ってても、それだけじゃ困ります? もいちどイチから! HTTP基礎訓練中(1) Webアプリのセキュリティについてもっと詳しく知りたいけれど、まず何を勉強すればいいの? そんな疑問に応える新連載! 「Security&Trust」フォーラム 2007/9/28 |
||
| マルチバイトの落とし穴 星野君のWebアプリほのぼの改造計画(10) 今日も赤坂さんとお勉強。ちゃんと対策されているようにみえるのに、こんな抜け穴があるなんて! 「Security&Trust」フォーラム 2006/9/23 |
||
| 世間の認識とのギャップ――XSSは本当に危ないか? 川口洋のセキュリティ・プライベート・アイズ(13) 脆弱性が1つでも残ってるだなんて論外という方も多いでしょう。ところでその脆弱性、いったい誰が攻撃するんでしょうか 「Security&Trust」フォーラム 2009/3/17 |
||
【2】強制的ブラウジング(強制的ブラウズ)
強制ブラウジングは、情報漏えいにつながる可能性の高い攻撃手法の1つで、リンクやボタンの遷移によらず特定のページに直接アクセスし、情報を取得します。
Webアプリケーションプログラム上で、パラメータとしてパス名などを受け入れた場合、Webサーバ経由で本来アクセス権限のないファイルを利用者が取得できてしまいます。このとき、個人情報やサーバの内部情報などが取得されてしまい、個人情報漏えいや、サーバへの攻撃の足掛かりとして利用される恐れがあります。
■ 対策
対策としては、例えばアクセスされてはいけない情報(個人情報など)をWebサーバのドキュメントルート上に置かないことなどが挙げられます。これは、強制ブラウジングに限らず、データ保存場所が原因となるセキュリティに対して有効です。
編集部注:上記強制的ブラウジングの対策は、対策の1つにすぎません。以下の記事などもご参考にしていただければと思います
次ページでは、残りの脆弱性のうち【3】〜【6】について見ていきます。
| Index | ||||||||||
|
||||||||||
Webアプリの常識をJSPとStrutsで身につける バックナンバー 連載インデックスへ»
- 第1回 いまさら聞けない、Webアプリケーションの常識
- 第2回 Strutsの常識を知り、EclipseとTomcatの環境構築
- 第3回 Webアプリにおけるサーバとクライアントの常識
- 第4回 HTMLやStrutsに必須の“タグ”と“サブミット”の常識
- 第5回 もはやWeb利用者の常識、“URL”の意味を理解しよう
- 第6回 発掘! Webの“あるある”問題点−ステートの常識
- 第7回 Webアプリ開発の常識、バリデーションとテンプレート
- 第8回 MySQLの常識を知りセットアップしてJSPからDB操作
- 第9回 Hibernateで覚えるO/RマッピングとBeanの常識
- 第10回 JUnitとEclipseを使って学ぶ、“テスト”の常識
- 第11回 Webアプリにおける11の脆弱性の常識と対策
- 最終回 JavaScript/Ajaxで知るWebアプリとスクリプトの常識
| Java Solution全記事一覧 |
TechTargetジャパン
- Play frameworkのコントローラの使い方を理解する (2013/5/9)
PlayにおけるMVCパターンのコントローラについて、URIやHTTPメソッドなどの扱い方を含めて解説します - “使用”より“構築”で学ぶオープンPaaS「OpenShift」 (2013/4/25)
オープンなクラウドで重要性を増すJava。どんな技術を使ってPaaSが実装されているのかを理解しよう - アジャイルってなんなんだ!? (2013/4/15)
Web開発企業『クレイ』におけるアジャイルソフトウェア開発の経験を漫画「ブラックジャックによろしく」を挿絵に紹介するドキュメンタリーです - Play 2.1にアップグレードしてコントローラを使いこなす (2013/4/11)
Play 2.0から2.1への移行方法やパラメータのバインド、リバースルーティング、セッション、フラッシュスコープの使い方などを解説
|
|
- ActionBarで、アプリのUIはこんなにスマートになる
- どうする、知財計画2013
- Windows 7/8でISOファイルをCD/DVD-Rに書き込む
- HTML5+CSS3のカンタン装飾設定で今風デザイン
- 標準ライブラリで提供される時間・エラー処理機能
- 再考・APT〜Mandiantレポートを基に〜
- DB界隈で聞こえてきた2つの新しいメッセージ
- Windows 8のシステム修復ディスクを作成する
- 起業家は、非現実的に楽観的だからこそ素晴らしい
- 手書きタブレット「enchantMOON」が当たります!
- モバイルファーストの本当の意味と、実践方法
- Play frameworkのコントローラの使い方を理解する
キャリアアップ
- - PR -
イベントカレンダー
- - PR -
転職/派遣情報を探す
**先週の人気講座ランキング**
〜 Android編 〜
ホワイトペーパー(TechTargetジャパン)
「ITmedia マーケティング」新着記事
なぜ人は商品購入時にネットのクチコミを参考にするのか
消費者はネットでどんな情報を得ているのだろうか。また、どこから情報を取得しているの...
米ケンタッキーフライドチキン、新製品に対する顧客の反応を共有するWebキャンペーンを実施
米ケンタッキーフライドチキン(以下、米KFC)は新製品の販売に関し、購入者の感想や商品...
第4回 ストーリーとは何か? 人を動かすために必要なもう1つの要素
適切なコンテンツをロジカルに導き出すためのコンテンツストラテジー。しかしこれだけで...