原文地址:https://www.cnblogs.com/zwqh/p/7182953.html
可以先看下这篇文章:通过FreeMarker生成word文档及导出PDF文件
当我们需要将文档展示到页面的时候,往往会想到将office相关文件转换成pdf,然后再通过h5标签等方式展示到页面,无论是使用libreoffice或者openoffice,转换后的pdf效果都会有一定的差别,但不影响使用,如果只是想做简单的文档展示功能,而又不想做得那么复杂,可以借用微软的在线展示office文件的链接,只需要在页面加个iframe即可:
https://view.officeapps.live.com/op/view.aspx?src=http://xxx.abc.cn/zzz.docx
src后面跟的是你文档所在服务器的具体地址。
---------------------
作者:ljihe
来源:CSDN
原文:https://blog.csdn.net/ljihe/article/details/77451117
版权声明:本文为博主原创文章,转载请附上博文链接!
1、poi:https://blog.csdn.net/owen_william/article/details/81290024
2、poi-tl:https://github.com/Sayi/poi-tl
导出pdf的方法如下:
1、https://blog.csdn.net/mynamepg/article/details/85789213
2、百度网盘源码(包含导出到word、导出到pdf、pdf导出到图片的项目):
链接:https://pan.baidu.com/s/1acnpMUt3anm251oYktdVJw z95i
前言
最近在项目中,因客户要求,将页面内容(如合同协议)导出成word,在网上翻了好多,感觉太乱了,不过最后还是较好解决了这个问题。
准备材料
1.word原件 2.编辑器(推荐Firstobject free XML editor)或者使用sublime(更推荐)
sublime使用方法:打开xml代码,修改关键位置的数据,这时候需要有格式化代码的工具,才能看到规整的代码,推荐使用sublime的格式化工具,需要安装,参照sublime格式化。选择selection->format->indent XML,就可以一键格式化当前XML文件
实现步骤
1.用Microsoft Office Word打开word原件;
2.把需要动态修改的内容替换成xxxxxxxx,如果有图片,尽量选择较小的图片几十K左右,并调整好位置;
3.另存为,选择保存类型Word 2003 XML 文档(*.xml)【这里说一下为什么用Microsoft Office Word打开且要保存为Word 2003XML,本人亲测,用WPS找不到Word 2003XML选项,如果保存为Word XML,会有兼容问题,避免出现导出的word文档不能用Word 2003打开的问题】,保存的文件名不要是中文;
4.用Firstobject free XML editor打开文件,选择Tools下的Indent【或者按快捷键F8】格式化文件内容。左边是文档结构,右边是文档内容;
5. 将文档内容中需要动态修改内容的地方,换成freemarker的标识。其实就是Map
6.在加入了图片占位的地方,会看到一片base64编码后的代码,把base64替换成${image},也就是Map
代码如:
注意:“>${image}<”这尖括号中间不能加任何其他的诸如空格,tab,换行等符号。
如果需要循环,则使用:<#list maps as map>#list> maps是Map
7. 标识替换完之后,模板就弄完了,另存为.ftl后缀文件即可。注意:一定不要用word打开ftl模板文件,否则xml内容会发生变化,导致前面的工作白做了。
另存为.ftl后缀文件的方法如图:
百度网盘源码:
代码实现
工具类WordUtils.Java
1 import java.io.File; 2 import java.io.FileInputStream; 3 import java.io.FileOutputStream; 4 import java.io.IOException; 5 import java.io.InputStream; 6 import java.io.OutputStreamWriter; 7 import java.io.Writer; 8 import java.net.URLEncoder; 9 import java.util.Date; 10 import java.util.Map; 11 12 import javax.servlet.ServletOutputStream; 13 import javax.servlet.http.HttpServletRequest; 14 import javax.servlet.http.HttpServletResponse; 15 16 import freemarker.template.Configuration; 17 import freemarker.template.Template; 18 19 public class WordUtils { 20 //配置信息,代码本身写的还是很可读的,就不过多注解了 21 private static Configuration configuration = null; 22 //这里注意的是利用WordUtils的类加载器动态获得模板文件的位置 23 // private static final String templateFolder = WordUtils.class.getClassLoader().getResource("../../").getPath() + "WEB-INF/templetes/"; 24 private static final String templateFolder = "H:/我的项目/lm/lm/web/src/main/webapp/WEB-INF/templates"; 25 static { 26 configuration = new Configuration(); 27 configuration.setDefaultEncoding("utf-8"); 28 try { 29 configuration.setDirectoryForTemplateLoading(new File(templateFolder)); 30 } catch (IOException e) { 31 e.printStackTrace(); 32 } 33 } 34 35 private WordUtils() { 36 throw new AssertionError(); 37 } 38 39 public static void exportMillCertificateWord(HttpServletRequest request, HttpServletResponse response, Map map,String title,String ftlFile) throws IOException { 40 Template freemarkerTemplate = configuration.getTemplate(ftlFile); 41 File file = null; 42 InputStream fin = null; 43 ServletOutputStream out = null; 44 try { 45 // 调用工具类的createDoc方法生成Word文档 46 file = createDoc(map,freemarkerTemplate); 47 fin = new FileInputStream(file); 48 49 response.setCharacterEncoding("utf-8"); 50 response.setContentType("application/msword"); 51 // 设置浏览器以下载的方式处理该文件名 52 String fileName = title+DateUtil.formatDateDetailTime(new Date()) + ".doc"; 53 response.setHeader("Content-Disposition", "attachment;filename=" 54 .concat(String.valueOf(URLEncoder.encode(fileName, "UTF-8")))); 55 56 out = response.getOutputStream(); 57 byte[] buffer = new byte[512]; // 缓冲区 58 int bytesToRead = -1; 59 // 通过循环将读入的Word文件的内容输出到浏览器中 60 while((bytesToRead = fin.read(buffer)) != -1) { 61 out.write(buffer, 0, bytesToRead); 62 } 63 } finally { 64 if(fin != null) fin.close(); 65 if(out != null) out.close(); 66 if(file != null) file.delete(); // 删除临时文件 67 } 68 } 69 70 private static File createDoc(Map, ?> dataMap, Template template) { 71 String name = "sellPlan.doc"; 72 File f = new File(name); 73 Template t = template; 74 try { 75 // 这个地方不能使用FileWriter因为需要指定编码类型否则生成的Word文档会因为有无法识别的编码而无法打开 76 Writer w = new OutputStreamWriter(new FileOutputStream(f), "utf-8"); 77 t.process(dataMap, w); 78 w.close(); 79 } catch (Exception ex) { 80 ex.printStackTrace(); 81 throw new RuntimeException(ex); 82 } 83 return f; 84 } 85 }
Action1 @RequestMapping("/exportSellPlan") 2 public @ResponseBody void exportSellPlan(Long id){ 3 Calendar calendar = Calendar.getInstance();// 取当前日期。 4 if(id!=null){ 5 SellPlan plan=sellService.getSellPlanInfo(id); 6 //获得数据 7 Map
Base64处理map = new HashMap (); 8 map.put("bYear", plan.getBusinessYear()!=null?plan.getBusinessYear():""); 9 map.put("lYear", plan.getLiveYear()!=null?plan.getLiveYear():""); 10 map.put("leader",plan.getLeader()!=null?plan.getLeader():""); 11 map.put("phone", plan.getPhone()!=null?plan.getPhone():""); 12 map.put("curYear", calendar.get(Calendar.YEAR)+""); 13 map.put("image", getImageBase(plan.getPositionImage())); 14 try { 15 WordUtils.exportMillCertificateWord(getRequest(),getResponse(),map,"方案","sellPlan.ftl"); 16 } catch (IOException e) { 17 // TODO Auto-generated catch block 18 e.printStackTrace(); 19 } 20 } 21 } 1 //获得图片的base64码 2 @SuppressWarnings("deprecation") 3 public String getImageBase(String src) { 4 if(src==null||src==""){ 5 return ""; 6 } 7 File file = new File(getRequest().getRealPath("/")+src.replace(getRequest().getContextPath(), "")); 8 if(!file.exists()) { 9 return ""; 10 } 11 InputStream in = null; 12 byte[] data = null; 13 try { 14 in = new FileInputStream(file); 15 } catch (FileNotFoundException e1) { 16 e1.printStackTrace(); 17 } 18 try { 19 data = new byte[in.available()]; 20 in.read(data); 21 in.close(); 22 } catch (IOException e) { 23 e.printStackTrace(); 24 } 25 BASE64Encoder encoder = new BASE64Encoder(); 26 return encoder.encode(data); 27 }
Javascript1 window.location.href="<%=path%>/exportSellPlan?id=" + id;
pom.xml结束语 如果对Freemarker标签不熟的,可以在网上先学习下,了解文档结构。 相关链接 Firstobject free XML editor下载地址:http://www.firstobject.com/dn_editor.htm freemarker 官网:http://freemarker.org/
org.freemarker freemarker 2.3.20
持之以恒
分类: Java
标签: Java, Word导出
朝雾轻寒
关注 - 0
粉丝 - 7
+加关注
4
1
« 上一篇:【windows】远程桌面 把远程服务器的explorer.exe进程关掉了,咋办?
» 下一篇:【百度地图】获取某个覆盖物的总面积
posted @ 2017-07-15 15:49 朝雾轻寒 阅读(22918) 评论(7) 编辑 收藏
评论列表
#1楼 2017-11-28 17:04 zymqqc
get !
支持(0)反对(0)
#2楼 2018-02-06 10:43 uuuuY
楼主问下如果导出的word带目录树,怎么处理??
支持(0)反对(0)
#3楼[楼主] 2018-02-06 11:03 朝雾轻寒
@ uuuuY
什么样的目录树?
支持(0)反对(0)
#4楼 2018-02-06 11:07 uuuuY
@朝雾轻寒
导出word文档的时候生成一个目录结构
像这样的!!!
支持(0)反对(0)
#5楼[楼主] 2018-02-06 11:12 朝雾轻寒
@ uuuuY
这个保存成xml时应该有相应的格式,可以循环出来,不过页码暂时不知道怎么处理。
支持(0)反对(0)
#6楼 2018-02-06 11:16 uuuuY
@朝雾轻寒
好吧,谢谢楼主!!!本来导出word功能已经实现的了(就是按照你的帖子的教程去做的),现在就是加了需求,导出的word要生成目录结构!!
支持(0)反对(0)
#7楼 2018-02-26 19:15 闪闪发光的代码
有得,支持一下,顺便补充两点
1)WPS也可以,另存为Word XML文档(最下面那个)
2)ftl文件的注释方式是 <#--注释内容-->
(旧版的<#comment> 注释 #comment>也还能用)