springboot下生成复杂word文档方案 在Word软件里面制作模板

系列文章目录

第二章:根据模板导出word,复合格式表格生成、可变列表格生成
第三章:doc和docx插入多图
第四章:web环境下word文档预览


为什么不用POI或者easypoi来做呢?
1.POI需要用太多代码来实现格式,如果在用户给定一个word模板,开发人员需要观察每个部分的格式、布局等来写代码,在复杂场景下效率太低。
2.easypoi无法实现细致的格式控制。如:一个表格第一行(标题行)宽边框,从第二行(内容行第一行)细边框,最后一行粗边框;这个应用场景比较多,但是easypoi无法实现。另外就是缺失了图片功能。

使用模板引擎来做生成word文档的优势在于:
1:可视化编辑模板,可以让产品经理或者具体的业务人员制作模板。
2:降低了代码量和调试难度,因为不用写代码来控制格式。
缺点:
1:每一次word样式调整都需要重新再次转换为模板引擎的模板。
这个Demo覆盖了动态带格式的文字、图片、表格。

在实际的复杂格式word文档场景下,使用模板引擎是比POI、easypoi更优的解决方案。如果是比较简单的word文档区别不大。

代码仓库

https://gitee.com/whatitis/springboot_freemarker_word

1. 制作word模板

1.1 制作一个word文档,设置好样式、排版

直接在word文档里面写freemarker占位符是没有用的,因为${}字符会被转换。
在这里插入图片描述

1.2 正常保存为word docx/doc文档留底

1.3 另存为一份Word XML 文档(*.xml)

在这里插入图片描述
这个是用于作为freemarker模板。

2. 准备一个springboot项目,引入freemarker-starter依赖

gradle

implementation 'org.springframework.boot:spring-boot-starter-freemarker:2.5.5'

TODO:贴上项目仓库地址

3. 调整配置文件

spring:
  freemarker:
    template-loader-path: classpath:/templates/word/
wordDemo:
  outDirectory: D:/temp # word文件输出目录
  basePackagePath: /templates/word/ # 自定义模板目录

4. 编辑模板文件

通过word另存为xml格式的文档,我们只需要在此基础上调整、增加一点代码就可以使用了。

4.1 将第1步的word xml 文档放到指定的模板目录

在这里插入图片描述

4.2 格式化模板文件

在这里插入图片描述

4.2.3 修改文件后缀名为.ftl

在这里插入图片描述

4.3 将word文件中要动态替换的内容用freemarker占位符替换

4.3.1 艺术字文字内容

我们按照关键字搜索到指定位置
在这里插入图片描述
这个艺术字有两处需要去替换,因为带有阴影效果。

将内容改为:${articleTitle}

4.3.2 图片

找到图片位置
在这里插入图片描述
可以看出来它是用base64来存储图片的,所以我们相对应的也用base64替换。

把原来的base64内容替换成占位符
在这里插入图片描述

4.3.3 表格处理

按照关键字搜索

user.name替换为:

在这里插入图片描述

user.gender段多了一些没用的代码,应该是一些多余的样式,删掉和user.name保持一致即可。
在这里插入图片描述
写循环代码

通过观察word xml代码,我们分析得知
user.name 所处的 <w:tr 标签段为表格中的一行,我们在其上写循环代码,这个就像JSP。

<#list> </#list>要包住 <w:tr></w:tr>

在这里插入图片描述

全部替换完毕之后保存。

5. 写代码

请看代码仓库里的内容。

https://gitee.com/whatitis/springboot_freemarker_word

运行测试

cn.gitee.worddemo.WorddemoApplicationTests#testProc

在这里插入图片描述

在这里插入图片描述

6.结果

在这里插入图片描述
在这里插入图片描述

1.艺术字替换完成
2.表格内容填充完成,样式保持OK。
3.页码自动生成。

测试通过。

FreeMarker官方在线手册中文版

http://freemarker.foofun.cn/dgui_template_directives.html

最佳实践

为了减少每一次word样式调整转换为模板引擎的模板时的工作量,可以视具体情况用最小部分替换法去做,这个方式需要你去识别word的xml标签,来决定替换的范围,比如某一页的内容格式修改了之后,就用这一页的xml替换ftl对应那一页的标签然后再去重新写freemarker标签。

word兼容性问题

如果需要在office word 2007 以及之前的版本上使用生成的结果,需要使用word xml 2003 格式来做模板。不然会出现生成的结果没法在老版word上打开的问题。

2次格式化可能会出现的问题

在这里插入图片描述

在制作word 2003 xml模板过程中,导入word xml格式到IDEA中,格式化一次,重命名文件为ftl之后再格式化一次,使用此模板生成的word doc 文档会出现图片不显示或者文档打开失败的情况。

这种情况下,只在导入word xml 到IDEA中格式化一次,然后手动格式化具体标签就不会出现问题。

在做word 2007模板时没有出现问题。

分页符处理

段落分页的处理;
1.如果分页符是段落前面需要判断是否第一页,不然会多出一个空白页。
2.如果分页符位于段落后面需要判断是否最后一页,不然会多出一个空白页。

分页符是需要依附于某个元素的,比如一段文字,如下:

                    <w:p wsp:rsidR="00230078" wsp:rsidRDefault="00415FB0">
                        <w:pPr>
                            <w:jc w:val="center"/>
                            <w:rPr>
                                <w:b/>
                                <w:sz w:val="24"/>
                                <w:sz-cs w:val="24"/>
                            </w:rPr>
                            
<#--                            判断是否第一页-->
                            <#if ttable_index != 0>
                                <w:br w:type="page"/>
                            </#if>

                        </w:pPr>
                        <w:r>
                            <w:rPr>
                                <w:rFonts w:hint="fareast"/>
                                <wx:font wx:val="宋体"/>
                                <w:b/>
                                <w:sz w:val="24"/>
                                <w:sz-cs
                                        w:val="24"/>
                            </w:rPr>
                            <w:t>我是一段文字,啦啦啦啦啦</w:t>
                        </w:r>
                    </w:p>

在这里插入图片描述

复合格式表格生成,请看第二章
在文章开头有链接

  • 1
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于Spring Boot使用Freemarker模板生成Word文档并加密的例子,可以按照以下步骤进行操作: 1. 首先,您需要在pom.xml文件中添加Freemarker和Apache POI的依赖项。在 `<dependencies>` 标签内添加以下代码: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.2</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.2</version> </dependency> ``` 2. 创建一个Freemarker模板文件,例如 `template.ftl`,并在其中编写Word文档的内容,可以使用Freemarker语法进行动态内容替换。 3. 创建一个Controller类,并添加以下代码: ```java import freemarker.template.Configuration; import freemarker.template.Template; import org.apache.poi.xwpf.usermodel.XWPFDocument; import org.apache.poi.xwpf.usermodel.XWPFEncryptor; import org.apache.poi.xwpf.usermodel.XWPFParagraph; import org.apache.poi.xwpf.usermodel.XWPFRun; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import javax.servlet.http.HttpServletResponse; import java.io.OutputStream; import java.util.HashMap; import java.util.Map; @Controller public class WordController { @Autowired private Configuration freemarkerConfiguration; @GetMapping("/generate-word") public void generateWord(HttpServletResponse response) throws Exception { // 加载Freemarker模板 Template template = freemarkerConfiguration.getTemplate("template.ftl"); // 创建Word文档对象 XWPFDocument document = new XWPFDocument(); // 创建段落对象 XWPFParagraph paragraph = document.createParagraph(); XWPFRun run = paragraph.createRun(); // 填充模板内容 Map<String, Object> data = new HashMap<>(); // 添加模板中需要的数据,可以根据实际需求自行修改 // 渲染模板 run.setText(templateToString(template, data)); // 加密Word文档 XWPFEncryptor encryptor = new XWPFEncryptor(document); encryptor.encrypt("password"); // 替换为您自己的密码 // 设置响应头 response.setHeader("Content-disposition", "attachment; filename=encrypted_word.docx"); response.setContentType("application/vnd.openxmlformats-officedocument.wordprocessingml.document"); // 导出Word文档 OutputStream outputStream = response.getOutputStream(); document.write(outputStream); outputStream.close(); } private String templateToString(Template template, Map<String, Object> data) throws Exception { StringWriter stringWriter = new StringWriter(); template.process(data, stringWriter); return stringWriter.toString(); } } ``` 4. 在Spring Boot的配置文件(例如 `application.properties`)中添加以下配置: ```properties spring.freemarker.template-loader-path=classpath:/templates/ ``` 5. 运行Spring Boot应用程序,并访问 `/generate-word` 路径,即可生成并下载加密的Word文档。 请注意,上述代码仅为示例,您可以根据实际需求进行修改和扩展。同时,为了确保文档的安全性,请根据您的需求修改加密密码和文件名。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值