jsp - 创建一个Excel文件供用户使用Apache POI下载

标签 jsp servlets apache-poi

我可以使用apache poi创建一个Excel文件。但是,我希望用户能够将其下载为“ true” excel文件。我想要实现的效果将是拥有一个允许用户下载文件的弹出框。这类似于使用

<%@ page contentType="application/vnd.ms-excel" pageEncoding="ISO-8859-1"%> 
<%response.setHeader("Content-Disposition", "attachment;filename=myfile.xls"); %>


有一个严重的例外:我必须允许用户下载正确的Excel文件。我在上面的代码中读到某处,只是对客户端说服务器正在发送一个excel文件

最佳答案

在普通的servlet中而不是JSP文件中完成该工作。 JSP文件用于动态生成HTML代码,并为此使用字符编写器,而不是二进制输出流,因此只会破坏您的POI生成的Excel文件,本质上是二进制流。

因此,基本上,您需要在servlet的doGet()方法中执行的所有操作如下:

response.setContentType("application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment; filename=filename.xls");
HSSFWorkbook workbook = new HSSFWorkbook();
// ...
// Now populate workbook the usual way.
// ...
workbook.write(response.getOutputStream()); // Write workbook to response.
workbook.close();


现在,要下载它,请通过其URL而不是JSP文件来调用servlet。

关于jsp - 创建一个Excel文件供用户使用Apache POI下载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57482767/

相关文章:

找不到 Java Servlet 205 命令

java - 通过tomcat在servlet中运行python脚本不起作用

java - Apache POI - 单元格 setCellValue 抛出 NullPointerException

java - 从 servlet 调用 jsp 时出现异常?

java - 将 JSP 部署到用户,如 setup.exe 或 .dmg 文件

java - 在spring中将数据从jsp表单发送到数据库(不使用servlet)

java - 如何在任何浏览器的保存/另存为弹出功能上将默认的保存/另存为路径修改为我们定义的路径?

java - apache poi 最大行数

java - 为什么 Servlet.service() for servlet jsp 会抛出这个异常?

java - JSP 第 31 行错误