是否可以使用HTTP POST下载文件? 我知道“获取”方式(windows.location),但在我的情况下,有很多param应该传递给服务器
答案 0 :(得分:16)
是的,POST请求的其余部分可以指示浏览器下载文件。文件内容将作为HTTP响应发送,与GET情况相同。
答案 1 :(得分:14)
看起来你想从Javascript生成POST请求。我相信没有办法让浏览器将AJAX请求的结果视为下载。即使Content-Type设置为浏览器通常提供的下载(例如“application / octet-stream”),浏览器也只会将数据存入XMLHttpRequest对象。
此外,您可能已经知道,没有办法让window.open()发出POST请求。
我认为最好的方法是制作一个AJAX请求,在服务器上生成一个文件。在浏览器上,当该请求完成时,使用window.open()下载生成的文件。
答案 2 :(得分:13)
你的意思是这样吗?
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");
}
答案 3 :(得分:4)
在某种意义上,每个HTTP GET或POST都是“下载文件”,但最好将其视为消息有效负载而不是文件。在大多数情况下,有效负载是HTML文档,浏览器应将其呈现为网页。但是,如果它不是HTML文档呢?如果它是一个zip文件,浏览器应该为用户提供“另存为”对话框怎么办?显然,浏览器必须确定响应的内容类型并正确处理它。
浏览器确定内容类型的最常见方式之一是通过HTTP header调用,相应地称为“内容类型”。此标头采用mime类型的值。这是浏览器执行内容特定事务的关键,例如在响应包含pdf文件时启动acrobat插件等。
注意,并非所有浏览器1)都以相同的方式确定内容类型,2)以相同的方式对内容类型做出反应。有时您必须设置标题以获得所有浏览器所需的行为。所有服务器端技术都允许您设置HTTP标头。
答案 4 :(得分:3)
除了请求方法以及如何将数据发送到服务器之外,没有区别。无论您使用GET还是POST,处理响应的方式都是相同的。
答案 5 :(得分:1)
我设法用这个来解决它:
<强> 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();
}
Spring Controller Code:
@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();
}