web-dev-qa-db-ja.com

HTTP POSTでファイルをダウンロードすることは可能ですか?

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

28
Sean

はい、残りのPOSTリクエストは、ブラウザにファイルをダウンロードするように指示できます。ファイルのコンテンツは、GETの場合と同様に、HTTP応答として送信されます。

17
Greg Hewgill

このような意味ですか?

    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");
    }
15
Stefan Steiger

JavaScriptからPOSTリクエストを生成したいようです。ブラウザにAJAXリクエストの結果を処理させる方法はないと思いますContent-Typeが、ブラウザが通常ダウンロードとして提供するもの(たとえば、「application/octet-stream」へ)に設定されている場合でも、ブラウザはXMLHttpRequestオブジェクトにデータを配置するだけです。

さらに、おそらくすでにご存じのとおり、window.open()にPOSTリクエストを発行させる方法はありません。

最善の方法は、サーバーにファイルを生成するAJAXリクエストを作成することです。ブラウザーで、そのリクエストが完了したら、window.open()を使用して生成されたファイルをダウンロードします。

14
James Clark

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

ブラウザがコンテンツタイプを決定する最も一般的な方法の1つは、 HTTPヘッダー を呼び出すことです。つまり、 "Content-Type"を呼び出します。このヘッダーは、mime-typeの値を取ります。これは、応答にpdfファイルが含まれている場合にacrobatプラグインを起動するなど、コンテンツ固有のことを行うブラウザーにとって重要です。

すべてのブラウザが1)同じ方法でコンテンツタイプを決定し、2)同じ方法でコンテンツタイプに反応するわけではないことに注意してください。場合によっては、ヘッダーを設定して、すべてのブラウザーから必要な動作を取得する必要があります。すべてのサーバー側テクノロジーでは、HTTPヘッダーを設定できます。

4
chad

リクエストメソッドとサーバーへのデータ送信方法以外に違いはありません。 GETとPOSTのどちらを使用しても、応答の処理方法は同じです。

3
Ted Hopp

私はこれを使ってそれを解決することができました:

service.js

downloadExcel : function() {
    var mapForm = document.createElement("form");
    mapForm.target ="_self"||"_blank";
    mapForm.id="stmtForm";
    mapForm.method = "POST";
    mapForm.action = "your_Controller_URL";

    var mapInput = document.createElement("input");
    mapInput.type = "hidden";
    mapInput.name = "Data";
    mapForm.appendChild(mapInput);
    document.body.appendChild(mapForm);

    mapForm.submit();
}

スプリングコントローラコード:

@Controller

@PostMapping(value = "/your_Controller_URL")
    public void doDownloadEmsTemplate( final HttpServletRequest request, final HttpServletResponse response)
            throws IOException, URISyntaxException {

        String filePath = "/location/zzzz.xls";
        logger.info("Excel Template File Location Path :" + filePath);
        final int BUFFER_SIZE = 4096;
        ServletContext context = request.getServletContext();
        String appPath = context.getRealPath("");
        String fullPath = appPath + filePath;
        File downloadFile = new File(fullPath);
        FileInputStream inputStream = new FileInputStream(downloadFile);
        String mimeType = context.getMimeType(fullPath);
        if (mimeType == null) {
            //mimeType = "application/octet-stream";
            mimeType = "application/vnd.ms-Excel";
        }
        logger.info("MIME type: " + mimeType);
        response.setContentType(mimeType);
        response.setContentLength((int) downloadFile.length());
        String headerKey = "Content-Disposition";
        String headerValue = String.format("attachment; filename=\"%s\"", downloadFile.getName());
        logger.info("File Download Successfully : ");
        response.setHeader(headerKey, headerValue);
        OutputStream outStream = response.getOutputStream();
        byte[] buffer = new byte[BUFFER_SIZE];
        int bytesRead = -1;
        while ((bytesRead = inputStream.read(buffer)) != -1) {
            outStream.write(buffer, 0, bytesRead);
        }
        inputStream.close();
        outStream.close();
    }
1
Saurabh