各位大佬好,我有一个同事后端写了这么一端excel文件输出代码,请问我前端js要怎么接收?
Workbook workbook = exportExcel(lsMap, ExcelType.HSSF);
request.setCharacterEncoding("utf-8");
respones.setCharacterEncoding("utf-8");
respones.setContentType("application/x-download");
String filedisplay = "product.xls";
filedisplay = URLEncoder.encode(filedisplay, "utf-8");
respones.addHeader("Content-Disposition", "attachment;filename=" + filedisplay);
OutputStream out = respones.getOutputStream();
workbook.write(out);
out.close();
方法1: 无需js,直接用a标签去接你的输出流
<a href="<你的返回流的Action路径>" >下载</a>
方法2:使用js,前提是你使用的是现代浏览器,支持html5特性(主要是新的XMLHTTPRequest对象,Blob)
<script type="text/javascript">
function download(filename) {
var oReq = new XMLHttpRequest();
oReq.open("GET", "<你的返回流的Action路径>", true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = filename;
elink.style.display = 'none';
var blob = new Blob([content]);
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
}
</script>