Java freemarker生成word模板文件(如合同文件)及转pdf文件方法
创建模板文件
ContractTemplate.docx

ContractTemplate.xml

导入的Jar包
compile("junit:junit")
compile("org.springframework:spring-test")
compile("org.springframework.boot:spring-boot-test")
testCompile 'org.springframework.boot:spring-boot-starter-test'

compile 'org.freemarker:freemarker:2.3.28'
compile 'fakepath:aspose-words:19.5jdk'
compile 'fakepath:aspose-cells:8.5.2'

Java工具类 xml文档 转换 Word XmlToDocx.java

package com.test.docxml.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.util.Enumeration;
import java.util.zip.ZipEntry;
import java.util.zip.ZipFile;
import java.util.zip.ZipOutputStream; /**
* xml文档 转换 Word
*/
public class XmlToDocx {
/**
*
* @param documentFile 动态生成数据的docunment.xml文件
* @param docxTemplate docx的模板
* @param toFilePath 需要导出的文件路径
* @throws Exception
*/ public static void outDocx(File documentFile, String docxTemplate, String toFilePath,String key) throws Exception {
try {
File docxFile = new File(docxTemplate);
ZipFile zipFile = new ZipFile(docxFile);
Enumeration<? extends ZipEntry> zipEntrys = zipFile.entries();
FileOutputStream fileOutputStream = new FileOutputStream(toFilePath);
ZipOutputStream zipout = new ZipOutputStream(fileOutputStream);
int len = -1;
byte[] buffer = new byte[1024];
while (zipEntrys.hasMoreElements()) {
ZipEntry next = zipEntrys.nextElement();
InputStream is = zipFile.getInputStream(next);
// 把输入流的文件传到输出流中 如果是word/document.xml由我们输入
zipout.putNextEntry(new ZipEntry(next.toString()));
if ("word/document.xml".equals(next.toString())) {
InputStream in = new FileInputStream(documentFile);
while ((len = in.read(buffer)) != -1) {
zipout.write(buffer, 0, len);
}
in.close();
} else {
while ((len = is.read(buffer)) != -1) {
zipout.write(buffer, 0, len);
}
is.close();
}
}
zipout.close();
} catch (Exception e) {
e.printStackTrace();
}
} }

Java工具类 word文档 转换 PDF WordToPdf.java

package com.test.docxml.utils;

import com.aspose.cells.*;
import com.aspose.cells.License;
import com.aspose.words.*; import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream; /**
* word文档 转换 PDF
*/
public class WordToPdf { /**
* 获取license许可凭证
* @return
*/
private static boolean getLicense() {
boolean result = false;
try {
String licenseStr = "<License>\n"
+ " <Data>\n"
+ " <Products>\n"
+ " <Product>Aspose.Total for Java</Product>\n"
+ " <Product>Aspose.Words for Java</Product>\n"
+ " </Products>\n"
+ " <EditionType>Enterprise</EditionType>\n"
+ " <SubscriptionExpiry>20991231</SubscriptionExpiry>\n"
+ " <LicenseExpiry>20991231</LicenseExpiry>\n"
+ " <SerialNumber>23dcc79f-44ec-4a23-be3a-03c1632404e9</SerialNumber>\n"
+ " </Data>\n"
+ " <Signature>0nRuwNEddXwLfXB7pw66G71MS93gW8mNzJ7vuh3Sf4VAEOBfpxtHLCotymv1PoeukxYe31K441Ivq0Pkvx1yZZG4O1KCv3Omdbs7uqzUB4xXHlOub4VsTODzDJ5MWHqlRCB1HHcGjlyT2sVGiovLt0Grvqw5+QXBuinoBY0suX0=</Signature>\n"
+ "</License>"; InputStream license = new ByteArrayInputStream(licenseStr.getBytes("UTF-8"));
License asposeLic = new License();
asposeLic.setLicense(license);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
} /**
* word文档 转换为 PDF
* @param inPath 源文件
* @param outPath 目标文件
*/
public static File doc2pdf(String inPath, String outPath) { //验证License,获取许可凭证
if (!getLicense()) {
return null;
}
//新建一个PDF文档
File file = new File(outPath);
try {
//新建一个IO输出流
FileOutputStream os = new FileOutputStream(file);
//获取将要被转化的word文档
Document doc = new Document(inPath);
// 全面支持DOC, DOCX,OOXML, RTF HTML,OpenDocument,PDF, EPUB, XPS,SWF 相互转换
doc.save(os, com.aspose.words.SaveFormat.PDF);
os.close(); } catch (Exception e) {
e.printStackTrace();
}
return file;
} public static void main(String[] args) {
doc2pdf("D:/1.doc", "D:/1.pdf");
}
}

Java单元测试类 XmlDocTest.java

package com.test.docxml;

import com.test.docxml.utils.WordToPdf;
import com.test.docxml.utils.XmlToDocx;
import freemarker.template.Configuration;
import freemarker.template.Template;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration; import java.io.File;
import java.io.PrintWriter;
import java.io.Writer;
import java.nio.charset.Charset;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map; /**
* 本地单元测试
*/
@RunWith(SpringJUnit4ClassRunner.class)
//@RunWith(SpringRunner.class)
@SpringBootTest(classes= TemplateApplication.class)
@WebAppConfiguration
public class XmlDocTest { //短租
@Test
public void testContract() throws Exception{ String contractNo = "1255445544";
String contractCorp = "银河宇宙无敌测试soft";
String contractDate = "2022-01-27";
String contractItem = "房地产交易中心";
String contractContent = "稳定发展中的文案1万字"; //doc xml模板文件
String docXml = "ContractTemplate.xml"; //使用替换内容
//xml中间临时文件
String xmlTemp = "tmp-ContractTemplate.xml";
//生成文件的doc文件
String toFilePath = contractNo + ".docx";
//模板文档
String docx = "ContractTemplate.docx";
//生成pdf文件
String toPdfFilePath = contractNo + ".pdf";; String CONTRACT_ROOT_URL = "/template"; Resource contractNormalPath = new ClassPathResource(CONTRACT_ROOT_URL + File.separator + docXml);
String docTemplate = contractNormalPath.getURI().getPath().replace(docXml, docx); //设置文件编码(注意点1)
Writer writer = new PrintWriter(new File(xmlTemp),"UTF-8");
Configuration configuration = new Configuration(Configuration.VERSION_2_3_28); configuration.setEncoding(Locale.CHINESE, Charset.forName("UTF-8").name());
//设置配置(注意点3)
configuration.setDefaultEncoding("UTF-8"); String filenametest = contractNormalPath.getURI().getPath().replace(docXml, "");
System.out.println("filenametest=" + filenametest); configuration.setDirectoryForTemplateLoading(new File(filenametest)); // Template template = configuration.getTemplate(ContractConstants.CONTRACT_NORMAL_URL+orderType+type+".xml");
//设置模板编码(注意点2)
Template template = configuration.getTemplate(docXml,"UTF-8"); //绝对地址 Map paramsMap = new HashMap();
paramsMap.put("contractCorp",contractCorp);
paramsMap.put("contractDate",contractDate);
paramsMap.put("contractNo",contractNo);
paramsMap.put("contractItem",contractItem);
paramsMap.put("contractContent",contractContent); template.process(paramsMap, writer);
XmlToDocx.outDocx(new File(xmlTemp), docTemplate, toFilePath, null);
System.out.println("do finish"); //转成pdf
WordToPdf.doc2pdf(toFilePath,toPdfFilePath); } }

创建成功之后的文件如下:

Java freemarker生成word模板文件(如合同文件)及转pdf文件方法的更多相关文章

  1. Java Freemarker生成word

    Java Freemarker生成word freeMaker 简介: FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代 ...

  2. Java Web项目中使用Freemarker生成Word文档遇到的问题

    这段时间项目中使用了freemarker生成word文档.在项目中遇到了几个问题,在这里记录一下.首先就是关于遍历遇到的坑.整行整行的遍历是很简单的,只需要在整行的<w:tr></w ...

  3. 使用freemarker生成word、html时图片显示问题

    使用freemarker生成word.html时图片显示问题 博客分类: Java 使用freemarker生成word时图片显示问题使用freemarker生成html时图片显示问题使用iText生 ...

  4. FreeMarker生成word

    FreeMarker生成word数据填充是通过,Map填充. Map dataMap = new HashMap<String, Object>(); List<User> l ...

  5. 使用freemarker生成xml模板

    今天在java交流群里有个人问我如何用freemarker生成xml模板文件,可以手动配置参数,于是我到网上百度了一下.发现有一位同行的博文写的很nice,于是我就照着他的代码敲了一遍,最后实现了,本 ...

  6. freemarker生成word,表格分页

    在做项目的过程中,使用到了freemarker生成word.又有一个需求,明细的要确定有多少页,这就用到了换页的xml标签了,找了我好久 <w:p ><w:r><w:br ...

  7. JSP生成WORD文档,EXCEL文档及PDF文档的方法

    转自:https://www.jb51.net/article/73528.htm 本文实例讲述了JSP生成WORD文档,EXCEL文档及PDF文档的方法.分享给大家供大家参考,具体如下: 在web- ...

  8. C# 将多个office文件转换及合并为一个PDF文件

    PDF文件介绍 PDF(Portable Document Format )文件源于20世纪90年代初期,如今早已成为了一种最流行的的文件格式之一.因为PDF文件有很多优点: 支持跨平台和跨设备共享 ...

  9. Java Web项目中使用Freemarker生成Word文档

    Web项目中生成Word文档的操作屡见不鲜.基于Java的解决方式也是非常多的,包含使用Jacob.Apache POI.Java2Word.iText等各种方式,事实上在从Office 2003開始 ...

  10. java使用freemarker 生成word文档

      java 生成word文档     最近需要做一个导出word的功能, 在网上搜了下, 有用POI,JXL,iText等jar生成一个word文件然后将数据写到该文件中,API非常繁琐而且拼出来的 ...

随机推荐

  1. dotnet 修复 GitHub Action 构建过程提示 NETSDK1127 错误

    本文告诉大家,如何修复 GitHub Action 构建过程提示 error NETSDK1127: The targeting pack Microsoft.WindowsDesktop.App.W ...

  2. 在 UOS 统信运行 dotnet 程序提示没有通过系统安全验证无法运行

    本文记录 dotnet 应用程序在 UOS 统信系统上运行时,提示 没有通过系统安全验证,无法运行 的问题 这个问题是因为没有开启 UOS 统信的开发者模式,直接将自己构建完成的包放上去跑导致的问题 ...

  3. Rancher管理K8s集群(14)

    一.Rancher介绍 1.1 Rancher简介 Rancher 是一个开源的企业级多集群 Kubernetes 管理平台,实现了 Kubernetes 集群在混合云+本地 数据中心的集中部署与管理 ...

  4. C语言笔记001-用C语言编写程序

    例2-1  在屏幕上显示一个短句"Hello World!". #include <stdio.h> int main(void) { printf("hel ...

  5. 一个完整的可以输出移动端当前省市(地理坐标)的html页面

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. Codeforces 题解集

    Codeforces Round 940 (Div. 2) and CodeCraft-23 Codeforces Round 940 (Div. 2) and CodeCraft-23 (A-E)

  7. 01 redis 基础入门

    目录 介绍 特点 redis与memcache比较 适用场景 redis 核心配置说明 Redis 对key的通用操作命令 字符串 Hash类型 课程学习地址: https://www.bilibil ...

  8. linux定时任务crontab 周期执行任务

    目录 1. crontab主要作用 2. 如何添加crontab 定时任务 3. 计划任务,crontab命令选项: 4. cron文件语法: 5. 查看计划任务 1 创建脚本文件test.py,在文 ...

  9. Linux — 物理内存管理

    物理内存的组织方式 物理内存是由连续的一页一页的块组成,每个物理页都有页号 每个页由struct page表示,放进数组里--平坦内存模型 SMP和NUMA SMP中,总线会称为瓶颈,因为数据都要经过 ...

  10. 一键自动化博客发布工具,用过的人都说好(51cto篇)

    51cto是一个优秀的博客平台,今天给大家讲解一下blog-auto-publishing-tools如何自动发布博客到51cto上. 当然在实现过程中有可能会遇到各种困难,不过不用担心,我们一个个来 ...