ASPファイルで、動的にCSVファイルを作成し、クライアントにダウンロードさせたいのですが、実際には、ファイルは作成せずに、ASPで直接、CSVフォーマットのファイルをダウンロードさせているように振舞わせることはできないでしょうか?
手順
クライアント サーバー
あるURL(A.ASP)にアクセス
A.ASPのスクリプトでCSVフォーマットを作成
クライアントに送信(多分、Response.Writeで)
ダウンロードダイアログが開く
「A.CSVをダウンロードしますか?」
のような感じ
ダウンロード、またはExcelが開く
というようなイメージです。
CSVファイルを作ってしまうと、複数のユーザーからほぼ同時に要求があった場合、望むCSVにならない可能性があり、また、毎回ファイル名を変えると、Webサーバー上にCSVファイルが沢山できてしまうため、何とかこの方法でやりたいのですが、何かよい方法はありませんでしょうか?
ちなみに次のようなASPファイルをしてみましたが、うまくいきません。
<%
Response.Content-Type="application/vnd.ms-excel"
Response.Write "1,2" & vbNewLine
Response.Write "3,4" & vbNewLine
%>
また、「vnd.ms-excel」を「oct-stream」でもだめでした。
何かよい知恵をお貸しください。
No.1
- 回答日時:
こんな感じのASP にするのではどうなのでしょう?
<html>
<head>
<meta HTTP-EQUIV="Content-type" CONTENT="application/vnd.ms-excel">
</head>
<body>
<%
Response.Write "1,2" & vbNewLine
...
%>
</body>
</html>
# 私は計算機屋ですが、ASP は触ったことが無いのではずしているかもしれません。
私もはじめそのような形でしてみました。
が、よく考えれば「<html></html>」の部分ですでにだめなのでは・・・
実際、だめでした。
ですが、早速のお答えありがとうございます。
また、何か在ればよろしくお願いします。
No.2ベストアンサー
- 回答日時:
これでOK!です。
<%
Response.AddHeader "Content-disposition", "filename=""motteke.csv"""
Response.ContentType="text/csv"
Response.Write "1,2" & vbNewLine
Response.Write "3,4" & vbNewLine
%>
"text/csv"は適当です(笑)
ありがとうございます。
できました。
私も、「Content-disposition」は使ってみたのですが、つづりが違っててできませんでした。(^_^;)
ところで、
Content-disposition; attachment;filename=motteke.csv
という書き方もあるようですが、「attachment」はどうゆう物なのでしょうか?
あるのとないのと、何か違いがあるのでしょうか?
No.3
- 回答日時:
以下でいけます
Response.ContentType = "text/plain"
Response.AddHeader "Content-Disposition", "attachment;filename=xxxxxx.csv"
sendtext = "'aaa','bbb'"
Response.Write sendtext
Response.End
ありがとうございます。
できました。
私も、「Content-disposition」は使ってみたのですが、つづりが違っててできませんでした。(^_^;)
ところで、
Content-disposition; attachment;filename=xxxx.csv
という書き方もあるようですが、「attachment」はどうゆう物なのでしょうか?
あるのとないのと、何か違いがあるのでしょうか?
それと、「ContentType」は、やはり「text/plain」が一番いいでしょうか?
ContentType自身は、昔は自由に決めることができた(今も?)と聞いたことがあるので難しいですが、どこかに参考になるような資料はないでしょうか?
No.4
- 回答日時:
ContentTypeに"text/csv"と適当ものを指定してることには理由があります。
IEなんかですと、ContentTypeをまともに見ないのでいいんですが、
Netscapeですと"text/plain"というまともなMIMEを指定すると、
ダウンロードのダイアログが出ず、ブラウザで表示してしまいます。
(IE5.5のSPなしでもバグがあったような)
Content-dispositionの"attachment"はその名の通り添付を意味します。
その他には"inline"があります。
今回の場合はどちらでもなさそうなので省略して
絶対にダウンロードになってほしいなという私の願いがこめられています。
(ファイル名さえ認識してくれればよい)
美しいやり方ではないですね。
ご回答ありがとうございます。
確かに、ContentTypeは使い方が難しいですね。
特にIEは、ContentTypeにほとんど関係がないというところは、プラットフォームに依存しないシステムを作る際には、大きな障害になりますね。
大変参考になりました。ありがとうございました。
No.5
- 回答日時:
ContentType,attachmentに関してはmkiiさんが解説しているので割愛します。
IEのBugはBinary Dataの時に発生するようですね。(5.5では出ないかも.....)
ContentTypeを以下のようにすれば回避できます。
Response.ContentType = "application/octet-stream-dummy; name=file1.exe"
IE以外の場合は
Response.ContentType = "application/octet-stream; name=file1.exe"
IEのBugは、バイナリデータの時ですか。参考になります。
今は、まだ、バイナリデータのダウンロードは必要がないですが、将来のときのためにきっちり覚えておくようにします。
本当にありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
ASPでDBから抽出した結果をCSVファイルに保存させる方法
Microsoft ASP
-
ASP.NETでのメッセージ画面を出すには
Microsoft ASP
-
ASPでCSVを出力させたいです
Microsoft ASP
-
-
4
ASP .NETでファイル選択ダイアログ
Microsoft ASP
-
5
CSVファイルをサーバからクライアントへダウンロードする方法
Microsoft ASP
-
6
VBScriptで数値にコンマを付けたいです
Visual Basic(VBA)
-
7
【ASP2.0】TextBoxのフォーカスアウトでPostBackを実装させたい
Microsoft ASP
-
8
EXCELファイルの複数ダウンロードについて
Microsoft ASP
-
9
クラシックASPでのエラー処理について
Microsoft ASP
-
10
【緊急】ASPでのExcel出力方法について
その他(開発・運用・管理)
-
11
【HTML】1クリックで複数ファイルをダウンロードしたい
HTML・CSS
-
12
IEからEdgeへの移行に伴うIMEの状態(ime-mode)
HTML・CSS
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルに張り付けた写真のフ...
-
onedrive にexcelファイルをア...
-
VBAでPDFを作成する際、同じ名...
-
C#からvbsを実行したい
-
ffftpでファイル取得が0バイト...
-
VB.NET Excelを読み込んでDataT...
-
aspxをhtmlに変換する方法について
-
マクロで同じフォルダにある画...
-
vba 空のデータをSplitする時の...
-
Accessのトグルボタンでサブフ...
-
phpのファイルがブラウザで開か...
-
【VB.NET】App.configにファイ...
-
VB.NETでMSComm が追加できず?
-
マクロコードについて
-
バッチで当日日付で作成される...
-
MIDIにおいて ステータスバイト...
-
Excelでボタン(フォームコント...
-
エクセルマクロについて
-
グラフをC#のASP.net MVCで表示...
-
Windows10にデュアルブートでXP...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
OpenTextFile で書き込みできま...
-
ASPでCSVファイルを作成しダウ...
-
ファイルダウンロードの開くで...
-
サーブレットからファイル名を...
-
Matlabでの図の最大化の方法
-
CSV形式のファイルをエクセル形...
-
csv形式でダウンロードさせたい...
-
[ASP]CSVダウンロード時に、直...
-
CSVファイルダウンロードダイア...
-
IE6でのダウンロードダイア...
-
Excelでdatファイルを作成??
-
複数のテキストファイルをexcel...
-
フォルダ作成用バッチファイル...
-
【Excel VBA】PDFを作成して,...
-
Microsoft Access エラー 3051
-
テキストファイルの文字色に色...
-
1フォルダに保存できるファイル...
-
VBAでファイルパスが長すぎてコ...
-
ダウンロード不可PDFファイルは...
-
Refreshで落ちる
おすすめ情報