是否可以使用HTTP POST下载文件?

是否可以使用HTTP POST下载文件? 我知道“获取”方式(windows.location),但在我的情况下,有很多param应该传递给服务器

是的,POST请求的其余部分可以指示浏览器下载文件。 文件内容将作为HTTP响应发送,与GET情况相同。

看起来你想从Javascript生成POST请求。 我相信没有办法让浏览器将AJAX请求的结果视为下载。 即使将Content-Type设置为浏览器通常作为下载提供的内容(例如,设置为“application / octet-stream”),浏览器也只将数据存放在XMLHttpRequest对象中。

此外,您可能已经知道,没有办法让window.open()发出POST请求。

我认为最好的方法是制作一个AJAX请求,在服务器上生成一个文件。 在浏览器上,当该请求完成时,使用window.open()下载生成的文件。

你的意思是这样的?

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/(?.+?),(?.+)").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"); } 

在某种意义上,每个HTTP GET或POST都是“下载文件”,但最好将其视为消息有效负载而不是文件。 在大多数情况下,有效负载是HTML文档,浏览器应将其呈现为网页。 但是,如果它不是HTML文档呢? 如果它是一个zip文件,浏览器应该为用户提供“另存为”对话框怎么办? 显然,浏览器必须确定响应的内容类型并正确处理它。

浏览器确定内容类型的最常见方式之一是通过称为“内容类型”的HTTP标头 。 此标头采用mime类型的值。 这是浏览器执行内容特定事务的关键,例如当响应包含pdf文件时启动acrobat插件等。

请注意,并非所有浏览器都以相同的方式确定内容类型,2)以相同的方式对内容类型做出反应。 有时你必须玩具设置标题以获得你想要的所有浏览器的行为。 所有服务器端技术都允许您设置HTTP标头。

除了请求方法以及如何将数据发送到服务器之外,没有区别。 无论您使用GET还是POST,处理响应的方式都是相同的。

我设法用这个来解决它:

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(); }