[HOWTO] 既知の MIME タイプに対し [ファイルのダウンロード] ダイアログ ボックスを開く

文書番号: 260519 - 対象製品
この記事は、以前は次の ID で公開されていました: JP260519
すべて展開する | すべて折りたたむ

概要

Web サーバーからドキュメントを提供する際、ユーザーが、そのドキュメントをブラウザで開かずに直接ディスクに保存できるよう、即座にプロンプトを表示したい場合があります。しかし Microsoft Word ("application/ms-word") などの MIME (Multipurpose Internet Mail Extensions) タイプに対する既定の動作は、Internet Explorer でドキュメントを開くようになっています。

Content-Disposition ヘッダを使って、この既定の動作を無効にすることができます。そのフォーマットは次のとおりです。
Content-Disposition: attachment; filename=fname.ext

詳細

Content-Disposition は、MIME ユーザー エージェントに対して添付ファイルの表示、処理方法を指示する MIME プロトコルの拡張機能です。Content-Disposition の有効な値の範囲は、RFC (Request for Comment) 1806 (この資料の「関連情報」を参照) で規定されています。 この資料では、"attachment" 引数に焦点を当てます。この引数は、対象のファイルをディスクに保存するよう、ユーザー エージェント (この資料では Internet Explorer) に指示します。

Internet Explorer がこのヘッダを受け取ると、[ファイルのダウンロード] ダイアログ ボックスが表示されます。そのファイル名ボックスには、ヘッダで指定されたファイル名が自動的に生成されます (これは仕様よる動作です。保存場所に関するダイアログをユーザーに表示することなく、ユーザーのコンピュータにドキュメントを保存する場合、この機能は使用できません)。

Internet Explorer を使って、ファイルに対し Content-Disposition ヘッダを指定することができますが、それには動的および静的の 2 つの方法が存在します。

ヘッダを動的に適用するには、Content-Disposition ヘッダをブラウザに送る ASP (Active Server Page) ファイルを作成します。Response.AddHeader メソッドを使って、Content-Disposition ヘッダを追加します。 次に例を示します。
Response.AddHeader "Content-Disposition","attachment; filename=fname.ext"
テキスト以外のドキュメントに対しバイナリ書き込みを実行する方法については、「サポート技術情報」(Microsoft Knowledge Base) の次の資料を参照してください。
193998 HOWTO: Read and Display Binary Data in ASP
この方法は、サーバー上のドキュメント ストアを保護したい場合に適しています。特にドキュメントがインターネットに存在する場合に最適です。

ヘッダを静的に適用するには、インターネット サービス マネージャ でドキュメントを右クリックし、[プロパティ] を選択します。[HTTP ヘッダ] タブを選択し、Content-Disposition ヘッダを入力します。この場合、ダウンロードするファイルは既に決まっているため、filename= パラメータは省略することも可能です。この方法は、システム上の幾つかのファイルのみに Content-Disposition を適用し、ASP のオーバーヘッドを増やしたくない場合に最適です。

この方法は、Internet Explorer 4.01 では動作しない点に注意してください。

なお、サーバー側から Content-Disposition ヘッダーを送信せずに、クライアント側の設定によりダイアログを表示させる場合には、以下の手順を実行します。

クライアント側のフォルダオプションで設定する方法:
  1. [マイ コンピュータ] をダブルクリックします。
  2. [ツール] メニューの [フォルダ オプション] をクリックします。
  3. [ファイル タイプ] タブをクリックします。
  4. [登録されているファイル タイプ] の下から、ダイアログを表示させたいファイルの種類を選択して、[詳細設定] ボタンをクリックします。
  5. [ダウンロード後に開く確認をする] (または [ダウンロード後に常に開くように設定する]) のチェックボックスをオフにし、[OK] をクリックします。
  6. [登録されているファイル タイプ] の下からファイルの種類を選択して、[詳細設定] ボタンをクリックします。
※ ただし、ファイルの種類によっては上記の手順で設定できないものもあります。


関連情報については、次の文書番号をクリックして「サポート技術情報」 (Microsoft Knowledge Base) を参照してください。
182315 FIX: Content-Disposition: Does Not Force File Download Dialog

関連情報

Request for Comment 1806: Content-Disposition

Internet Explorer 用の Web ベース ソリューションの開発に関する詳細については、以下の Web サイトを参照してください。

http://msdn.microsoft.com/library/en-us/shellcc/platform/shell/reference/enums/filetypeattributeflags.asp

http://www.microsoft.com/japan/developer/workshop/default.asp

http://msdn2.microsoft.com/en-us/ie/default.aspx

http://support.microsoft.com/iep

関連情報

この資料は米国 Microsoft Corporation から提供されている Knowledge Base の Article ID 260519 (最終更新日 2001-09-13) をもとに作成したものです。

この資料に含まれているサンプル コード/プログラムは英語版を前提に書かれたものをありのままに記述しており、日本語環境での動作は確認されておりません。

プロパティ

文書番号: 260519 - 最終更新日: 2006年12月25日 - リビジョン: 4.1
この資料は以下の製品について記述したものです。
  • Microsoft Internet Explorer 5.0
  • Microsoft Internet Explorer 6.0
  • Microsoft Internet Explorer 6.0 Service Pack 1
キーワード:?
kbgrpdsinet kbhowto kbie kbie400 kbie500 kbie501 kbie550 kbnavigation KB260519
"Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。"

フィードバック