ボタンをクリックしたときに、クライアントにデータベースに保存されているファイルをダウンロードしてもらいたい。このajaxリクエストを送信し、サーバー側から取得します。
EXTJS:
downloadFile: function (a, b, c) {
var feed_id =this.getMyfeedwindow().down('form').getComponent('FeedId').text;
Ext.Ajax.request({
url: '/Feed/Download',
method: 'GET',
params: {
fileID: feed_id, //this.form.getComponent('file').value,
},
failure: function (response) {
alert('failed !');
},
success: function (response) {
alert('success!');
},
});
},
次に、このコードブロックで要求に応えます。
C#:
public void Download(string fileID){
Response.ContentType = "application/force-download";
Response.AddHeader("Content-Disposition", "attachment; Filename=\"Logo1.jpg\"");
Response.BinaryWrite(data);
Response.End();
}
ファイアバグでネットワークをチェックしたところ、これらのパラメータでリクエストが正常に返されるようです。
Cache-Control private
Content-Disposition attachment; filename="Logo1.jpg"
Content-Type application/force-download
Date Wed, 09 Jan 2013 12:51:54 GMT
Server Microsoft-IIS/8.0
Transfer-Encoding chunked
X-AspNet-Version 4.0.30319
X-AspNetMvc-Version 4.0
X-Powered-By ASP.NET
X-SourceFiles =?UTF-8?B?RTpcVXRrdUNhblxQcm9qZWN0c1xURlNcQlRPTVxCVE9NXEZlZWRcRG93bmxvYWQ=?=
正常に戻りますが、ダウンロードは開始されません。私はたくさんの質問や記事を読みましたが、ほとんどの回答は、force-downloadヘッダーを追加することで問題が解決すると言っています。どのポイントが恋しいですか?ありがとう。