java freemarker 导出富文本到Word文档

本文档介绍了如何使用Freemarker将包含富文本(如HTML标签)的内容导出到Word文档。通过创建模板并修改.ftl文件,处理图片的base64编码和链接,确保在不同环境下图片能正常显示。文章提供了详细步骤和测试过程。
摘要由CSDN通过智能技术生成

最近一直在加班 导致看到代码就想吐 今天抽出时间来记录一下 用freemaker导出富文本信息

之前使用freemaker导出图片等信息时 使用的是xml方式,不明白的 可以看 freemaker生成Word文档(图片、超链接)

由于xml方式 不识别<p><b>等这种HTML标签,所以只能使用mht方式来解决,话不多说 干起来!

我是看到 前辈 的文章 才 有所启发!

1.准备好模板

这里我要强调一下 模板里面插入图片时 不要使用插入->上传图片,这样会是超链接的形式,里面使用的绝对路径 当把文档转给他人时 图片显示不出来

   这种上传图片方式是错误的  应该直接复制图片到Word文档中

此时,模板已生成

将模板内容替换为占位符(${})形式  此时建议保留图片 这样分析文档结构 方便些

后另存为 单个文件网页(*.mht,*.mhtml)文件,于是生成一个.mht文件  最后调整后缀名为ftl文件

 

2.ftl占位符修改

  • 全文检索gb2312/utf-8把他改成utf-8,同时需要加上3D前缀

  • ${}占位符 中间会生成一些其他字符 需要将其他扰乱信息去掉 只保留占位符

  • 记住这三处标识  【NextPart_ 和 Content-Location】 这里文档 全都是一样的 所以在生成图片base64定义时  也要保持一致

  • 添加  ${imagesBase64String!""} 标识    在folHlink下面添加 该标识 存放图片base64信息

  • 添加  ${imagesXmlHrefString!""} 标识    在filelist.xml 上面添加 该标识 存放图片base64的链接信息

  • 去掉之前 保留的图片信息对应代码

其实添加的 ${imagesBase64String}和${imagesXmlHrefString}标识 就是 首先定义一个图片的base64,然后在下面引用,随后在正文中 直接调用图片的引用即可。

不明白的 可以看一下 其他图片的生成方式 【上面建议保留一张图片, 就是为了方便文档结构中图片的分析】

例如:看一下图片 image004.jpg

  • 图片base64的定义

  • 图片链接的引用

  • 图片的显示 调用图片链接的引用   <v:shape>xxxxx</v:shape>及后面的<img/> 这些是页面显示的图片 需要动态生成

此时 报告的模板修改 已经完成,下面开始上代码

因为 本项目的富文本存储的形式 为base64,而不是存储图片的地址,所以需要先根据base64生成图片 在进行操作。

  • 测试数据
Map<String, Object> dataMap = new HashMap<>();
List<String> photoNameList=new ArrayList<>();
String handledBase64Block = ""; //base64
String xmlimaHref = ""; //图片链接
//模拟数据
StringBuilder sb = new StringBuilder();
sb.append("<div>");
sb.append("<p>概况</p><p><br></p><p><img src=\"\"></p><p><br></p><p><span style=\"color: rgb(230, 0, 0);\" class=\"ql-size-large\">去掉ip校验</span></p>");
        sb.append("<p><span style=\"color: rgb(77, 77, 77);\">利用</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">来解析带</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">图片的富文本,思路是:</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板另存为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">mht</code><span style=\"color: rgb(77, 77, 77);\">格式,再修改后缀为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">ftl</code><span style=\"color: rgb(77, 77, 77);\">。将</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">字符串的图片,填充到制作的模板上。</span></p><p><span style=\"color: rgb(77, 77, 77);\">首先我们需要填充的</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板如下:</span></p>");
sb.append("</div>");
RichHtmlHandler test1handler = new RichHtmlHandler(sb.toString());
test1handler.setDocSrcLocationPrex("file:///C:/5181FBD1");
test1handler.setDocSrcParent("file3105.files");
test1handler.setNextPartId("01D73090.2D92D3A0");
test1handler.setShapeidPrex("_x56fe__x7247__x0020");
test1handler.setSpidPrex("_x0000_i");
test1handler.setTypeid("#_x0000_t75");
try {
     test1handler.handledHtml(false,filePath);
} catch (IOException e) {
     e.printStackTrace();
}
if (test1handler.getDocBase64BlockResults() != null
       && test1handler.getDocBase64BlockResults().size() > 0) {
     for (String item : test1handler.getDocBase64BlockResults()) {
        handledBase64Block += item + "\n";
     }
}
if (test1handler.getXmlImgRefs() != null
       && test1handler.getXmlImgRefs().size() > 0) {
       for (String item : test1handler.getXmlImgRefs()) {
         xmlimaHref += item + "\n";
       }
}
String bodyBlock = test1handler.getHandledDocBodyBlock();
dataMap.put("test1",bodyBlock);


StringBuilder sbTest2 = new StringBuilder();
sbTest2.append("<div>");
sbTest2.append("<img src=\"
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值