gihyo.jp » DEVELOPER STAGE » 連載 » なぜPHPアプリにセキュリティホールが多いのか? » 補講 » 【スクリプトインジェクション対策03】セッションIDが利用できる範囲を制限する

なぜPHPアプリにセキュリティホールが多いのか?

【スクリプトインジェクション対策03】セッションIDが利用できる範囲を制限する

クッキーには参照可能な範囲を制限する機能が定義されています。

  • パス
  • プロトコル
  • スクリプトからのアクセス

の3種類の制限方法があります。制限するのではなく,反対に参照可能な範囲をドメインパラメータで増やすことも可能です。当然ですが参照可能なドメインを増やすのは好ましくありません。セッションIDを共用するアプリケーションが増えれば増えるほど,スクリプトインジェクションなどでセッションIDが漏洩するリスクが増加します。

同じドメインで複数のアプリケーションを利用している場合,パスでセッションIDを保存したクッキー送信を制限することができます。例えば,www.example.comドメインの/myapp/以下にアプリケーションがインストールされている場合,session_set_cookie_params関数を用いて以下のURLからのみクッキーを参照可能に設定できます。

http://www.example.com/myapp/
session_set_cookie_params関数
void session_set_cookie_params ( int $lifetime [, string $path [, string $domain [, bool $secure [, bool $httponly ]]]] )

例:セッションIDクッキーにパスを設定

session_set_cookie_params(0, '/myapp/');
session_start();

SSLが有効な場合のみにクッキーが参照できるオプションもあります。

例:セッションIDクッキーがHTTPSプロトコルの場合に利用可能に設定する

session_set_cookie_params(0, '/myapp/', 'www.example.com', true);
session_start()

ログインしたセッションIDを保存するクッキーをHTTPSプロトコルでのみ利用されるのであれば,このオプションを有効にすると盗聴によるセッションハイジャックからも保護されます。特にセキュリティが重要なサービスを提供しているサイトの場合,ログイン状態を管理するセッションIDはHTTPSプロトコルでのみ送信可能に設定すべきです。

インターネット標準機能ではないですが,JavaScriptからクッキーにアクセスできなくするオプションも設定可能です。Internet ExplorerとFirefoxにはこの機能が実装されています。

例:JavaScriptからのアクセスを許可しない

session_set_cookie_params(0, '/myapp/', 'www.example.com', true, true);
session_start()

重要な情報にアクセス可能な範囲を可能な限り限定することはセキュリティ対策の基本です。しかし,多くのサイトで実践されているか?というと,大手サイトでも不十分なサイトが少なくありません。

既に解説済みで繰り返しになりますが,セッションIDが利用できる範囲を制限するためにも,セッションIDには必ずセッションクッキーを利用しなければなりません。PHPにはURLやフォームにセッションIDを埋め込むTransSID機能があります。しかしこの機能を利用すると,メールやブックマークにセッションIDが記録されセッションIDが漏えいする危険性が高くなります。このため,セッション管理にはクッキーを利用します。

とはいえ,有効期限が設定されたクッキーはローカルPC上ではファイルなどに保存されます。ユーザが共有PCを利用したりするとセッションIDがファイルに保存され,漏えいするリスクが高くなります。有効期限が0のクッキーはセッションクッキーと呼ばれブラウザのメモリのみに保存されます。例えアプリケーションがログアウトをサポートしていないようなアプリケーションであっても,セッションクッキーはメモリ上に保存されているのでブラウザが終了すると削除されます。

セッションクッキーを利用するとクッキー情報がファイルに保存されないので,ファイル共有やリモートログインを利用してクッキーファイルからセッションIDを盗まれるリスクをなくすことも可能です。

対策のまとめ

  • クッキーを参照可能なドメインは増やさない
  • パス属性を設定できる場合は必ず設定する
  • SSLセッションで使うセッションIDはhttpsプロトコルでのみ利用可能にする
  • スクリプトからクッキーにアクセスしなくてもよい場合はhttponly属性を使用する
  • セッションIDには必ずセッションクッキーを利用する

著者プロフィール

大垣靖男(おおがきやすお)

University of Denver卒。同校にてコンピュータサイエンスとビジネスを学ぶ。株式会社シーエーシーを経て,エレクトロニック・サービス・イニシアチブ有限会社を設立。
オープンソース製品は比較的古くから利用し,Linuxは0.9xのころから利用している。オープンソースシステム開発への参加はエレクトロニック・サービス・イニシアチブ設立後から。PHPプロジェクトでは,PostgreSQLモジュールのメンテナンスを担当している。

URLhttp://blog.ohgaki.net/

著書

  • Webアプリセキュリティ対策入門〜あなたのサイトは大丈夫?

    Webアプリセキュリティ対策入門〜あなたのサイトは大丈夫?

  • [改訂版]PHPポケットリファレンス

    [改訂版]PHPポケットリファレンス

コメント

コメントの記入

パスサポ

多数の情報処理技術者試験対策書籍の発行実績を誇る技術評論社がお届けする,資格試験合格サイト「めざせ! 情報処理試験 パスサポ」が開設されました。

ピックアップ

サクセスストーリーに続く,快適サーバー運用管理のヒント!

データの増大,煩雑な管理,システムダウン,セキュリティなど,迫りくる課題からシステム管理者の負担を軽くするポイントを解説します。

gihyo.jp インフラエンジニア情報局

ネットワークやITにかかわるあらゆる業種で必要とされるインフラエンジニアに向けた技術情報や心構え,その魅力について多角的に紹介。

テストエンジニア ステーション

いま,ITに関わるあらゆる開発業務で注目されつつあるテスト系エンジニアをターゲットにしたコンテンツサイトを展開します。

一行クイックアンケート

gihyo.jpで取り上げてほしいネタは?

※検索はページ右上の検索ボックスをご利用ください。

その他の連載

2010年版SEO体得講座

本連載では,いまや企業サイトの戦略の1つとして欠かすことのできないSEOについて,最新トレンドからすぐに使えるTipsまでを紹介します。

小型Linuxサーバの最高峰 OpenBlockS 600活用指南

搭載メモリの増加,CPUクロックの向上など,あらゆる面が強化された期待の新モデルOpenBlockS 600。この記事ではOpenBlockS 600の紹介から,活用するためのさまざまなノウハウを紹介していきます。

はじめMath! Javaでコンピュータ数学

プログラミング言語入門者向けに,知っていると役立つ数学的トピックスを紹介します。簡単な演習問題と解説で,即活用できる知識を目指します。

教科書には載っていない ネットワークエンジニアの実践技術

ネットワークエンジニア,インフラエンジニアのトラブル対応には,時には「教科書通りにいかない」テクニックが必要となります。資格試験では得られないこうした実践的な技術について,実例を元に紹介します。

Googleケータイ,世に現る

2008年9月,Googleが中心となって開発されている「Android」を採用した携帯電話「T-Mobile G1」が発表されました。本連載ではT-Mobile G1を中心にGoogleケータイに迫ります。

モバゲーオープンプラットフォームに挑戦!――面白法人カヤック流モバゲーオープンプラットフォーム企画と開発のイロハ

2010年1月にリリースとなったモバゲーオープンプラットフォーム。その制作企業であるカヤックが,アイデアを企画に落とし込み,開発までのノウハウを紹介します。

プロトタイピングツールSketchFlowを用いた,Silverlightアプリ開発

SketchFlowプロトタイプ作成からアプリケーション開発までをExpression Blend 3を使って実践的に解説します。

Ubuntu Weekly Recipe

Ubuntuの強力なデスクトップ機能を活用するための,いろいろなレシピをお届けします。

連載一覧

gihyo.jp

  • DEVELOPER STAGE
  • ADMINISTRATOR STAGE
  • WEB+DESIGN STAGE
  • LIFESTYLE STAGE
  • SCIENCE STAGE
  • NEWS & REPORT

書籍案内

  • 新刊書籍
  • 書籍ジャンル一覧
  • 書籍シリーズ一覧
  • 新刊ピックアップ
  • ロングセラー
  • 電脳会議

定期刊行物一覧

  • Software Design
  • WEB+DB PRESS
  • Web Site Expert
  • 組込みプレス

最近のコメント