2011-09-27 16 views
15

HTTP POSTでファイルをダウンロードすることはできますか? 私は "取得"方法(windows.location)を知っていますが、私の場合、サーバーに渡す必要がある多くのパラメータがあります。HTTP POSTでファイルをダウンロードすることはできますか?

+0

これはPOSTの利点で、多くのデータ(別名ペイロード)を送信できます。セキュリティもそこにありますが、あなたのケースではパラメータを送信することが必須です。 – EMM

答えて

14

はい、残りのPOST要求は、ファイル。ファイルの内容は、GETの場合と同様にHTTP応答として送信されます。

3

リクエスト方法とサーバーへのデータ送信方法以外に違いはありません。応答を処理する方法は、GETまたはPOSTのどちらを使用するかにかかわらず同じです。

+0

こんにちはグレッグ、あなたは例を挙げることができますか?ありがとうございます – Sean

4

ある意味では、すべてのHTTP GETまたはPOSTは「ファイルのダウンロード」ですが、ファイルではなくメッセージのペイロードと考える方がよいでしょう。ほとんどの場合、ペイロードはブラウザがWebページとしてレンダリングするHTMLドキュメントです。しかし、もしそれがHTML文書でないなら、どうでしょうか?ブラウザがユーザーに「名前を付けて保存」ダイアログを提供するzipファイルの場合はどうなりますか?明らかに、ブラウザはレスポンスのコンテンツタイプについて決定し、正しく処理する必要があります。

ブラウザがコンテンツタイプを決定する最も一般的な方法の1つは、「Content-Type」と呼ばれるHTTP headerです。このヘッダーは、MIMEタイプの値をとります。これは、レスポンスにpdfファイルなどが含まれている場合に、アクロバットプラグインを起動するようなコンテンツ固有の処理を行うブラウザの鍵です。

すべてのブラウザで同じではないコンテンツタイプを判別します。同じ方法でコンテンツタイプに変換します。場合によっては、すべてのブラウザから必要な動作を得るためにヘッダーを設定して遊ぶ必要があります。すべてのサーバー側のテクノロジでHTTPヘッダーを設定できます。

12

JavascriptからPOSTリクエストを生成したいようです。私は、ブラウザにAJAXリクエストの結果をダウンロードとして扱わせる方法がないと信じています。 Content-Typeが、ブラウザが通常ダウンロードとして提供するもの(例えば「アプリケーション/オクテットストリーム」)に設定されていても、ブラウザはXMLHttpRequestオブジェクトにのみデータを格納します。

さらに、すでに知っているように、window.open()がPOSTリクエストを発行する方法はありません。

私は最良の方法は、サーバー上のファイルを生成するAJAX要求を行うことだと思います。ブラウザーで、その要求が完了したら、window.open()を使用して生成されたファイルをダウンロードします。

+0

これは可能な解決策の1つです。もう1つは適切なファイルを取得するためにフォーム提出を実行しています。 –

11

このような意味ですか?このサーバー・コードで

function IssuePostRequest(objData) 
    { 
     var strPageURL = "about:blank"; 
     var strAction = "@Url.Action("GetPDF", "Home")/"; 
     //var strAction = "/popups/delete.aspx"; 

     var strWindowName = "MyEvilHttpPostInAnewWindow"; // ifrmDownload 
     var iWindowWidth = 805; 
     var iWindowHeight = 625; 



     var form = document.createElement("form"); 
     form.setAttribute("id", "bla"); 
     form.setAttribute("method", "post"); 
     form.setAttribute("action", strAction); 
     form.setAttribute("target", strWindowName); 
     form.setAttribute("style", "display: none;"); 
     // setting form target to a window named 'formresult' 


     // Repeat for all data fields 
     var hiddenField = document.createElement("input"); 
     hiddenField.setAttribute("name", "data"); 
     hiddenField.setAttribute("value", objData); 
     form.appendChild(hiddenField); 
     // End Repeat for all data fields 


     document.body.appendChild(form); 



     // creating the 'formresult' window with custom features prior to submitting the form 
     //window.open(test.html, 'formresult', 'scrollbars=no,menubar=no,height=600,width=800,resizable=yes,toolbar=no,status=no'); 
     //JS_PopupCenterScreen(strPageURL, strWindowName, iWindowWidth, iWindowHeight); 
     window.open(strPageURL, strWindowName); 

     // document.forms[0].submit(); 
     //document.getElementById("xxx").click(); 
     form.submit(); 
    } // End Function IssuePostRequest 

public FileResult GetPDF(string data) 
    { 
     //data = @""; 

     string base64Data = System.Text.RegularExpressions.Regex.Match(data, @"data:image/(?<type>.+?),(?<data>.+)").Groups["data"].Value; 
     byte[] binData = Convert.FromBase64String(base64Data); 

     byte[] ba = PdfHandler.ImageToPdf(binData); 
     //System.IO.File.WriteAllBytes(@"d:\temp\myba.pdf", ba); 

     //return System.Convert.ToBase64String(ba); 
     return File(ba, "application/pdf", "Chart.pdf"); 
    } 
+0

これは本当に役に立ちます、ありがとうございます。唯一の問題は、新しいウィンドウを開くことです。これはiFrameで開くことができますか? –

+2

@Menelaos Vergis: