需求描述
我需要将word的模板,按照相应栏位以及数据库的信息,动态生成一个word文档到本地。word模板仅支持word2003,并且包含图片。
工具技术
IDE:eclipse
JDK:1.7
Freemaker:2.3
Word模板:
准备工作:Word->FTL文件(很重要)
- 将需要用到图片的地方,全部使用真实图片代替
- 然后另存为xml文档
- 然后使用工具firstobject XML Editor打开(XML编辑器,可以格式调整)
按F8调整格式
4.新建工程(这里测试,所以新建Java Project),目录结构如图
- 接下来,新建包以及outfile.ftl文件,将调整后的xml文件复制到outfile.ftl内,然后把工程的格式调整为UTF-8,否则乱码,然后把文件内的”???????”全部替换为”宋体”,最后把图片的二进制改成${pic}
- 最后把你需要动态生成的参数全部修改成${key},ftl文件准备完成
工程代码
package com.esunny.zcq;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.HashMap;
import java.util.Map;
import sun.misc.BASE64Encoder;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;
public class DocumentHandler {
private Configuration configuration = null;
public DocumentHandler() {
configuration = new Configuration();
configuration.setDefaultEncoding("UTF-8");// 设置默认编码方式
}
/**
* !注意dataMap里存放的数据Key值要与模板中的参数相对应,图片为String类型的Base64编码
*
* @param dataMap
* 载入的数据文件
* @param templatePackagePath
* 模版文件包路径
* @param templateName
* 模版文件名称
* @param docPath
* 写出的doc文件路径
*/
public void createDoc(Map<String, Object> dataMap, String templatePackagePath, String templateName,
String docPath) {
// 设置模本装置方法和路径,FreeMarker支持多种模板装载方法。可以重servlet,classpath,数据库装载,
// // 这里我们的模板是放在com.havenliu.document.template包下面
configuration.setClassForTemplateLoading(this.getClass(), templatePackagePath);
Template t = null;
try {
t = configuration.getTemplate(templateName, "utf-8");
} catch (IOException e) {
e.printStackTrace();
}
// 输出文档路径及名称
File outFile = new File(docPath);
Writer out = null;
try {
out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8"));
} catch (Exception e1) {
e1.printStackTrace();
}
try {
t.process(dataMap, out);
} catch (TemplateException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
private String getImageStr(String imgFile) {
InputStream in = null;
byte[] data = null;
try {
in = new FileInputStream(imgFile);
data = new byte[in.available()];
in.read(data);
in.close();
} catch (IOException e) {
e.printStackTrace();
}
BASE64Encoder encoder = new BASE64Encoder();
return encoder.encode(data);
}
/**
*
* 测试
*/
public static void main(String[] args) {
DocumentHandler documentHandler = new DocumentHandler();
Map<String, Object> dataMap = new HashMap<String, Object>();
dataMap.put("pic", documentHandler.getImageStr("D:\\avater.jpg"));
dataMap.put("hy", "已婚");
dataMap.put("zz", "群众");
documentHandler.createDoc(dataMap, "/com/template", "outFile.ftl", "D:/out.doc");
}
}
工具及源码下载
apache-freemarker-2.3.25-incubating-bin.jar
源码FreemarkerTest.zip
firstobject XML Editor