前端代HTML代码:
<a href="requestUrl"><span id="downloadDocumentText">点击触发</span></a>
前端代JQuery代码:
<script type="application/javascript">
$('#downloadDocumentText').click();
</script>
后台代码:
public void downloadDocument (HttpServletRequest request, HttpServletResponse response) throws IOException {
// 下载本地文件
// 设置文件名fileName 这里做了特殊处理(防止中文名称输出到前端之后变成下划线
// 如果不需要进行处理可以使用String fileName = "批量布控.xlsx";
// String fileName = new String (request.getParameter("filename").getBytes("UTF-8"),"ISO_8859_1");
String fileName =new String ("批量布控.xlsx".getBytes("UTF-8"),"ISO_8859_1");
// 读到流中
response.setContentType("text/html;charset=utf-8");
//通知浏览器以下载的方式打开
response.addHeader("Content-Type","application/octet-stream");
response.addHeader("Content-Disposition","attachment;filename="+fileName);
//通过文件输入流读取文件
InputStream in=new FileInputStream("sinosoft-yjs-webs\\sinosoft-yjs-web-zdgzry\\src\\main\\resources\\templates\\document\\批量布控.xlsx");
//通过文件输出流写入文件
OutputStream out=response.getOutputStream();
byte[] bytes=new byte[1024];
int len=0;
//循环将写入流
while ((len=in.read(bytes))!=-1){
out.write(bytes,0,len);
}
// 关闭资源
out.flush();
out.close();
}