最近做一个项目,本来是直接在网页上查看文本信息,然后给客户直接打印的,但是发现也许是浏览器还是打印机的原因,总之,有个客户打印出来的格式始终与其他的不同,没办法,最后想到了直接将数据库中的信息生成一个Word文档,供客户下载,这样因为事先模板已经设置后,所以客户可以直接打印,也可以根据自己的爱好,调整格式,废话不多说,讲讲项目。

首先,这个用到了freemarker,先把用到的可能用到的jar包给大家看看:

opencv-2410.jar  
freemarker.jar
sun.misc.BASE64Decoder.jar

  需要这三个jar包的朋友,可以直接@我;

开始项目步骤:

1、在新建一个Word文档,将你想好的模板格式设计好

  

审美观不好,大家多多见谅,这里红色标记的部分是插入的图片,这里就没将图片插进去了。 相信细心的朋友也看见了里面很多我是用${*}来代替的,这个很关键,每一个都代表你动态往里面填充的数据,在后台填充的时候也是根据里面的代码来执行的。

2、模板生成好了之后,选择另存为,将Word文档保存为后缀名为xml的文本信息,

选择保存。

3、保存之后,用记事本打开xml文件,你会发现里面的内容成了这样

是不是完全看不懂,没关系,仔细看下,你会发现里面很多你编辑的内容都在,比如{*}这种,也可能觉得格式不对,小伙伴别着急,回头你放在eclipse里面,格式化一下,就好看多了;当然,这里的注意,由于收入法以及个人打字习惯的原因,在Word里面编辑的时候会出现${*}分开的时候,这时,你打开xml就发现变成了${* ,隔了好大一部分代码才有一个},这种是执行不了的,所以个人建议是事先在txt文档中写好,复制过去;还有,你插入的图片这里会识别不了,成为乱码,别着急,搜索<pkg:binaryData>,找到首位部分,替换一下,我替换之后成了这样<pkg:binaryData>${papersImg}</pkg:binaryData>,最后选择保存;

4、下面开始讲解代码编写,导包就不多说了,这里把项目用到的代码给大家粘贴下面,我个人比较懒,代码我也加了注释,方便测试人看,所以也就不给大家细细讲解了,有不懂的可以私下问我;

package com.inquiry.util;

import java.io.BufferedWriter;
import java.io.DataInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.net.URL;
import java.net.URLConnection;
import java.util.HashMap;
import java.util.Map; import com.inquiry.vo.WordSetVo; import Decoder.BASE64Encoder;
import freemarker.template.Configuration;
import freemarker.template.Template; public class CreateWord { /**
* 将对应的图片放入Word文档中
* @param imgFile
* @return
*/
private static 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);
} /**
*
* @param vo word数据回填
* @param status 审核进度
* @param saveAddress //文件保存地址
*/
public static void setData(WordSetVo vo ,int status, String saveAddress,String path) {
Map<String, Object> map = new HashMap<String, Object>();
// 编号
map.put("formid", vo.getFormNumber());
// 证件照
map.put("papersImg", getImageStr(downloadPicture(vo.getPapersImg(),path)));
// 现场照
map.put("spotImg", getImageStr(downloadPicture(vo.getSpotImg(),path)));
// 姓名
map.put("name", vo.getName());
// 曾用名
if (vo.getFormName() != null) {
map.put("formName", vo.getFormName());
} else {
map.put("formName", "");
}
// 性别
map.put("gender", vo.getGender());
// 民族
map.put("ethnicGroups", vo.getEthnicGroups()); // 年龄
map.put("age", vo.getAge());
// 学历
map.put("eduBg",vo.getEduBg());
// 婚姻状况
map.put("maritalStatus", vo.getMaritalStatus());
// 原户籍地
map.put("originalResidence", vo.getOriginalResidence());
// 现户籍地
map.put("nowResidence", vo.getNowResidence());
// 身份证
map.put("idcard", vo.getIdcard());
// 申请证件类别
map.put("papersType", vo.getPapersType()); // 联系电话
map.put("phone", vo.getPhone());
// 紧急联系人
if (vo.getLinkMan() != null) {
map.put("linkMan", vo.getLinkMan());
} else {
map.put("linkMan", " ");
}
// 联系人电话
if (vo.getLinkPhone() != null) {
map.put("linkPhone", vo.getLinkPhone());
} else {
map.put("linkPhone", " ");
}
// 现住址
if (vo.getAddress()!= null) {
map.put("address", vo.getAddress());
} else {
map.put("address", " ");
}
// 工作单位
if (vo.getWorkUnit()!= null) {
map.put("workUnit", vo.getWorkUnit());
} else {
map.put("workUnit", " ");
}
// 任职情况
if (vo.getPosition() != null) {
map.put("position", vo.getPosition());
} else {
map.put("position", " ");
}
// 迁入时间
if (vo.getImmigrationTime() != null) {
map.put("immigrationTime", vo.getImmigrationTime());
} else {
map.put("immigrationTime", " ");
}
// 迁入原因
if (vo.getImmigrationCause() != null) {
map.put("immigrationCause", vo.getImmigrationCause());
} else {
map.put("immigrationCause", " ");
}
// 出境事由
if (vo.getExitCause() != null) {
map.put("exitCause",vo.getExitCause());
} else {
map.put("exitCause", " ");
} if(status==1){
//县国保大队
setXgb(map,vo,path);
}
else if(status ==2){
setXgb(map,vo,path);
//市国保支队
setXfk(map,vo,path);
}else if(status == 3){
setXgb(map,vo,path);
setXfk(map,vo,path);
//市反恐支队
setSgb(map,vo,path);
} try { // 生成文件的路径及文件名。
File outFile = new File(saveAddress); Writer out = new BufferedWriter(new OutputStreamWriter(
new FileOutputStream(outFile), "UTF-8")); // 使用FileTemplateLoader
//选择调用的模板
String tempname = null ; if(status==1){
tempname = "temp1.xml";
}else if(status==2){
tempname = "temp2.xml";
}else if(status==3){
tempname = "temp3.xml";
}else if(status==0){
tempname = "temp0.xml";
} Configuration configuration = new Configuration();
configuration.setDefaultEncoding("utf-8");
configuration.setClassForTemplateLoading( CreateWord.class,"/com/inquiry/xml"); Template t = configuration.getTemplate(tempname, "UTF-8"); t.process(map, out);
out.flush();
out.close(); } catch (Exception e) {
e.printStackTrace();
}
} /**
* 回填县国保大队
* @param map
* @param vo
*/
private static void setXgb(Map<String, Object> map , WordSetVo vo,String path){
map.put("xgb", vo.getXgb());
map.put("xgdc", vo.getXgdc());
map.put("xgsh", vo.getXgsh());
map.put("xgdate", vo.getXgdate());
map.put("xggz", getImageStr(downloadPicture(vo.getXggz(),path)));
map.put("xgremark", vo.getXgremark());
} /**
* 回填市国保支队
* @param map
* @param vo
*/
private static void setXfk(Map<String, Object> map , WordSetVo vo,String path){
map.put("xfb", vo.getXfb());
map.put("xfdc", vo.getXfdc());
map.put("xfsh", vo.getXfsh());
map.put("xfdate", vo.getXfdate());
map.put("xfgz", getImageStr(downloadPicture(vo.getXfgz(),path)));
map.put("xfremark", vo.getXfremark());
} /**
* 回填市反恐支队
* @param map
* @param vo
*/
private static void setSgb(Map<String, Object> map , WordSetVo vo,String path){
map.put("sgb", vo.getSgb());
map.put("sgdc", vo.getSgdc());
map.put("sgsh", vo.getSgsh());
map.put("sgdate", vo.getSgdate());
map.put("sggz", getImageStr(downloadPicture(vo.getSggz(),path)));
map.put("sgremark", vo.getSgremark());
}
/**
* 传入要下载的图片的url列表,将url所对应的图片下载到本地
* @param urlList
*/
public static String downloadPicture(String urlString,String path) {
URL url = null;
String imgPath = null;
try {
url = new URL(path+urlString); // 打开URL连接
URLConnection con = url.openConnection();
// 得到URL的输入流
InputStream input = con.getInputStream();
// 设置数据缓冲
byte[] bs = new byte[1024 * 2];
// 读取到的数据长度
int len;
// 输出的文件流保存图片至本地
imgPath = createFile()+"/"+urlString.split("/")[urlString.split("/").length-1];
OutputStream os = new FileOutputStream(imgPath);
while ((len = input.read(bs)) != -1) {
os.write(bs, 0, len);
}
os.close();
input.close();
return imgPath; } catch (Exception e) {
e.printStackTrace();
} return imgPath;
} /**
* 在本地创建文件保存位置
* @return
*/
public static String createFile(){
//定义下载文件保存位置
String address = "C://inquiry";
File file = new File(address);
if (!file.exists()) {
file.mkdir();
}
return address;
}
}

最后就只剩下传数据测试咯,注意一下,图片地址必须给正确,不然会报错哦。

使用Freemarker创建word文档的更多相关文章

  1. freemarker导出word文档

    使用freemarker导出word文档的过程 **************************************************************************** ...

  2. Java使用freemarker导出word文档

    通过freemarker,以及JAVA,导出word文档. 共分为三步: 第一步:创建模板文件 第二步:通过JAVA创建返回值. 第三步:执行 分别介绍如下: 第一步: 首先创建word文档,按照想要 ...

  3. C#实现通过模板自动创建Word文档的方法

    原文地址:http://www.jb51.net/article/55332.htm   本文实例讲述了C#实现通过模板自动创建Word文档的方法,是非常实用的技巧.分享给大家供大家参考.具体实现方法 ...

  4. 在C#中创建word文档

    在下面文档中  首先引用word组件:Microsoft.Office.Interop.Word 在头文件中写上 using Word = Microsoft.Office.Interop.Word; ...

  5. freemarker导出word文档——WordXML格式解析

    前不久,公司一个项目需要实现导出文档的功能,之前是一个同事在做,做了3个星期,终于完成了,但是在项目上线之后却发现导出的文档有问题,此时,这个同事已经离职,我自然成为接班者,要把导出功能实现,但是我看 ...

  6. Java 后台创建word 文档

    ---恢复内容开始--- Java 后台创建 word 文档 自己总结  网上查阅的文档 分享POI 教程地址:http://www.tuicool.com/articles/emqaEf6 方式一. ...

  7. [java,2017-05-04] 创建word文档

    package test; import java.text.SimpleDateFormat; import java.util.Date; import com.aspose.words.Data ...

  8. OpenXml SDK 2.0 创建Word文档 添加页、段落、页眉和页脚

    using (WordprocessingDocument objWordDocument = WordprocessingDocument.Create(@"C:\********.doc ...

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

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

随机推荐

  1. 使用TeamCity对项目进行可持续集成管理

    使用TeamCity对项目进行可持续集成管理 一.可持续集成管理   持续集成,CI:即Continuous integration. 可持续集成的概念是基于团队(小组)协作开发而提出来的,为了提高团 ...

  2. C# 我的注册表操作类

    using System; using System.Collections.Generic; using System.Text; using Microsoft.Win32; using Syst ...

  3. lua及luci学习

    由于项目需要对Luci进行修改,所以这里开始地luci进行较深入的研究. 探索其中的运行路径. Openwrt默认的HTTP服务器为uhttpd,该WEB服务器是由Luci的开发者自行开发的,非常小巧 ...

  4. linux下getrusage()

    #include <sys/resource.h> /* Return resource usage information on process indicated by WHOand ...

  5. VMware7安装CentOS6.5教程

    VMware7安装CentOS6.5教程 http://www.91linux.com/html/2014/CentOS_0415/9727.html工欲善其事,必先利其器.学习linux系统,必须先 ...

  6. 在OpenWrt上编写自己的硬件操作程序

    上一篇文章中有写到如何使用OPENWRT的SDK,这里继续,写怎么在上面开发自己的应用程序. 我欲在OpenWrt上编写一个软件,它能够去读取某个AD芯片的多通道采样值. 在看这篇文章之前请看这官方的 ...

  7. SSIS Package to Call Web Service

    原文 SSIS Package to Call Web Service SSIS Package to Call Web Service. You can Call WebService from S ...

  8. Asp.Net MVC页面静态化功能实现一:利用IHttpModule,摒弃ResultFilter

    上一篇有提到利用IHttpModule和ResultFilter实现页面静态化功能.后来经过一些改动,将ResultFilter中要实现的功能全部转移到IHttpModule中来实现 Asp.Net ...

  9. Dev环境中的集成测试用例执行时上下文环境检查(实战)

    Dev环境中的集成测试用例执行时上下文环境检查(实战) Microsoft.NET 解决方案,项目开发必知必会. 从这篇文章开始我将分享一系列我认为在实际工作中很有必要的一些.NET项目开发的核心技术 ...

  10. 使用 ArcGIS Online和APP进行监控操作和数据采集

    主要介绍的App是Operations Dashboard for ArcGIS 和 Collector for ArcGIS,它们 提高了组织内日常操作的效率.精度和响应速度. 已经购买了 ArcG ...