首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何发送新创建的excel文件而不将其保存到硬盘上?

如何发送新创建的excel文件而不将其保存到硬盘上?
EN

Stack Overflow用户
提问于 2017-02-10 17:37:49
回答 1查看 1.5K关注 0票数 0
代码语言:javascript
复制
    List<String> headerRow = Arrays.asList("col1", "col2", "col3","col4","col5"); 
    // Creates a xlsx workbook !!
    XSSFWorkbook wb = ExcelHelper.writeToXlsxExcelFile(headerRow,EjbHelper.getAccountEJb().getCustomersByscPartyNumber("9B7W5")); 
    //Creating a file to dump xlsx
    String fileLocation = "d://try.xlsx";
    FileOutputStream fout = new FileOutputStream(fileLocation);
    workbook.write(fout);
    //Want to Create a Webservice to send response without saving file to hard-disk 
    ResponseBuilder response = Response.ok((Object)fout);
    response.header("Content-Disposition","attachment; filename=" + "ResourceInformation.xlsx");
    return response.build();

上面的代码片段创建了一个xlsx文件,然后通过响应.I发送它,想知道有什么方法可以直接发送xlsx文件而不在硬盘上创建文件吗?

EN

回答 1

Stack Overflow用户

发布于 2017-02-10 17:54:31

我认为更简单的方法是直接使用HttpServletResponse

代码语言:javascript
复制
 public void yourMethod(@Context HttpServletResponse httpServletResponse) {
    List<String> headerRow = Arrays.asList("col1", "col2", "col3","col4","col5"); 
    Workbook wb = ExcelHelper.writeToXlsxExcelFile(headerRow,EjbHelper.getAccountEJb().getCustomersByscPartyNumber("9B7W5"));
    response.setHeader("Content-Disposition","attachment; filename=" + "ResourceInformation.xlsx");
    wb.write(response.getOutputStream());
    response.flushBuffer();
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42156017

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档