java下载word

需要引入word模板的依赖,pom增加如下jar报包依赖

XML 复制代码
    <!--word模板-->
        <dependency>
            <groupId>com.deepoove</groupId>
            <artifactId>poi-tl</artifactId>
            <version>1.9.1</version>
        </dependency>

但测试的时候发现,word模板填充时报错

com.deepoove.poi.exception.ResolverException: Compile template failed

at com.deepoove.poi.XWPFTemplate.compile(XWPFTemplate.java:116)

at cn.org.bjca.ywq.his.ca.controller.OrderInfoController.renderTemplate(OrderInfoController.java:307)

at cn.org.bjca.ywq.his.ca.controller.OrderInfoController.downloadCaReport(OrderInfoController.java:286)

at cn.org.bjca.ywq.his.ca.controller.OrderInfoController$$FastClassBySpringCGLIB$$5f1b3564.invoke(<generated>)

at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218)

at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:771)

at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)

at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:749)

at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:95)

Caused by: java.io.IOException: ZIP entry size is too large or invalid

at org.apache.poi.openxml4j.util.ZipArchiveFakeEntry.<init>(ZipArchiveFakeEntry.java:43)

at org.apache.poi.openxml4j.util.ZipInputStreamZipEntrySource.<init>(ZipInputStreamZipEntrySource.java:53)

at org.apache.poi.openxml4j.opc.ZipPackage.<init>(ZipPackage.java:106)

at org.apache.poi.openxml4j.opc.OPCPackage.open(OPCPackage.java:307)

at org.apache.poi.ooxml.util.PackageHelper.open(PackageHelper.java:47)

at org.apache.poi.xwpf.usermodel.XWPFDocument.<init>(XWPFDocument.java:142)

搜了各种资料,原来maven打包时把resource下的word模板压缩了,导致读取模板文件时失败了。

完整的word模板和下载程序如下:

java 复制代码
  @RequestMapping(value = "/downloadDocx", method = RequestMethod.GET)
    public void downloadDocx(HttpServletResponse response) {

        //根据业务查询数据,并组装模板中要替换的params,这里也可以使用guava工具类直接将java dto转换成map
        Map<String, Object> params = new HashMap<>();
try {

            //模板放在项目的 resource目录下的templates目录,模板里需要替换的变量使用EL表达式标识,比如 {{userName}}   在params中有个key为userName的
            ClassPathResource resource = new ClassPathResource("templates\\test.docx");
            XWPFTemplate template = renderTemplate(resource.getStream(), params);

            response.setContentType("application/octet-stream;charset=utf-8");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("test", StandardCharsets.UTF_8.name()) + ".docx");
            try (OutputStream out = response.getOutputStream()) {
                template.writeAndClose(out);
            } catch (IOException e) {
                logger.error("io异常", e);
            }

        } catch (Exception e) {
            logger.error("下载docx异常", e);
        }

}


/**
     * 模板替换
     * @param templateInputStream
     * @param dataMap
     * @return
     */
private XWPFTemplate renderTemplate(InputStream templateInputStream, Map<String, Object> dataMap) {
        ConfigureBuilder configureBuilder = Configure.builder()
                .useSpringEL()  // 启用Spring EL表达式 模板中使用 {{}} {{userName}}
                .bind("dataTable", new HackLoopTableRenderPolicy());  // 设置循环策略
        Configure config = configureBuilder.build();
        return XWPFTemplate.compile(templateInputStream, config).render(dataMap);

    }

参考:java.io.IOException: ZIP entry size is too large or invalid-CSDN博客

相关推荐
开开心心就好4 小时前
文档格式转换软件 一键Word转PDF
开发语言·前端·数据库·pdf·c#·word
乘风归趣1 天前
spire.doc在word中生成公式
java·开发语言·word
爱转呼啦圈的小兔子1 天前
Mac中修改Word的Normal.dotm文件
macos·word
传奇开心果编程1 天前
【传奇开心果系列】Flet框架实现的图形化界面的PDF转word转换器办公小工具自定义模板
前端·python·学习·ui·前端框架·pdf·word
柴狗狗1 天前
poi生成word固定表格列宽
word
我命由我123454 天前
Excel 表格 - 合并单元格、清除单元格格式
运维·word·powerpoint·excel·工具·表格·软件工具
小付同学呀4 天前
word——如何给封面、目录、摘要、正文设置不同的页码
word
Quz4 天前
使用VBA宏批量修改Word中表格题注格式
word
PythonFun5 天前
基于Python的Word文件翻译器(免费下载)
word
修昔底德5 天前
一个适用于 Word(Mac/Win 通用) 的 VBA 宏:把所有“上角标格式的 0‑9”以及 “Unicode 上角标数字 ⁰‑⁹” 批量删除。
word