echarts 生成统计图时,自动保存图片到服务器,并使用freemarker生成word。
1.项目工程截图如下:
需要echarts包和生成word的freemarker-2.3.8.jar包
2.index.jsp页面中的代码:
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <%
- String path = request.getContextPath();
- String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
- %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>ECharts 生成报表 并保存图片</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="This is my page">
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css">
- -->
- </head>
- <body>
- <!-- 为ECharts准备一个具备大小(宽高)的Dom -->
- <div id="main" style="height:400px"></div>
- <!-- ECharts单文件引入 -->
- <script src="<%=basePath %>js/echarts/build/dist/echarts.js"></script>
- <script type="text/javascript">
- // 路径配置
- require.config({
- paths: {
- echarts: '<%=basePath %>js/echarts/build/dist'
- }
- });
- // 使用
- require(
- [
- 'echarts',
- 'echarts/chart/bar' // 使用柱状图就加载bar模块,按需加载
- ],
- function (ec) {
- // 基于准备好的dom,初始化echarts图表
- var myChart = ec.init(document.getElementById('main'));
- var option = {
- tooltip: {
- show: true
- },
- legend: {
- data:['销量']
- },
- xAxis : [
- {
- type : 'category',
- data : ["衬衫","羊毛衫","雪纺衫","裤子","高跟鞋","袜子"]
- }
- ],
- yAxis : [
- {
- type : 'value'
- }
- ],
- series : [
- {
- "name":"销量",
- "type":"bar",
- "data":[5, 20, 40, 10, 10, 20]
- }
- ]
- };
- // 为echarts对象加载数据
- myChart.setOption(option);
- setTimeout(exportImage, 2000);
- function exportImage(){
- var data = "a="+encodeURIComponent(myChart.getDataURL("png"));
- var xmlhttp;
- if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari
- xmlhttp = new XMLHttpRequest();
- } else { // code for IE6, IE5
- xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
- }
- xmlhttp.open("POST","<%=path%>/servlet/saveImage",true);
- xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
- xmlhttp.onreadystatechange = function() {
- if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
- alert("保存成功");
- }
- }
- xmlhttp.send(data);
- }
- }
- );
- </script>
- </body>
- </html>
3.web.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <web-app version="2.5"
- xmlns="http://java.sun.com/xml/ns/javaee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
- http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
- <display-name></display-name>
- <welcome-file-list>
- <welcome-file>index.jsp</welcome-file>
- </welcome-file-list>
- <servlet>
- <servlet-name>saveImage</servlet-name>
- <servlet-class>com.servlet.SaveImage</servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>saveImage</servlet-name>
- <url-pattern>/servlet/saveImage</url-pattern>
- </servlet-mapping>
- </web-app>
4.SaveImage.java
- package com.servlet;
- 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.util.ArrayList;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import com.word.WordUtil;
- import sun.misc.BASE64Decoder;
- import sun.misc.BASE64Encoder;
- public class SaveImage extends HttpServlet {
- private static final long serialVersionUID = -1915463532411657451L;
- public void init() throws ServletException {
- }
- protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException {
- }
- protected void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException {
- String a = request.getParameter("a");
- try {
- String[] url = a.split(",");
- String u = url[1];
- // Base64解码
- byte[] b = new BASE64Decoder().decodeBuffer(u);
- WordUtil wordUtil = new WordUtil();
- String fileStr = wordUtil.saveFile();
- // 生成图片
- OutputStream out = new FileOutputStream(new File(fileStr+"\\test.png"));
- out.write(b);
- out.flush();
- out.close();
- //数据模拟,如果是真实编写,可以建service层,dao层进行数据的获取
- Map<String, Object> dataMap = new HashMap<String, Object>();
- dataMap = getData();
- //生产word
- wordUtil.createWord("2.ftl", fileStr+"\\test.doc", dataMap);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- public Map<String, Object> getData() {
- Map<String, Object> dataMap = new HashMap<String, Object>();
- WordUtil wordUtil = new WordUtil();
- String fileStr = wordUtil.saveFile();
- dataMap.put("image", getImageStr(fileStr+"\\test.png"));
- List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();
- for (int i = 0; i < 2; i++) {
- Map<String,Object> map = new HashMap<String,Object>();
- map.put("xuhao", i);
- map.put("neirong", "内容"+i);
- list.add(map);
- }
- dataMap.put("list", list);
- dataMap.put("info", "测试");
- return dataMap;
- }
- public 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);
- }
- }
5.WordUtil.java
- package com.word;
- import java.io.BufferedWriter;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.FileNotFoundException;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.io.OutputStreamWriter;
- import java.io.Writer;
- import java.util.Map;
- import sun.misc.BASE64Encoder;
- import freemarker.template.Configuration;
- import freemarker.template.Template;
- import freemarker.template.TemplateException;
- public class WordUtil {
- private Configuration configuration = null;
- public WordUtil() {
- configuration = new Configuration();
- configuration.setDefaultEncoding("utf-8");
- }
- public void createWord(String templetName, String filePathName, Map<String, Object> dataMap) {
- configuration.setClassForTemplateLoading(this.getClass(), "/com/word"); // FTL文件所存在的位置
- Template t = null;
- try {
- // 获取模版文件
- t = configuration.getTemplate(templetName);
- } catch (IOException e) {
- e.printStackTrace();
- }
- // 生成文件的路径和名称
- File outFile = new File(filePathName);
- Writer out = null;
- try {
- out = new BufferedWriter(new OutputStreamWriter(
- new FileOutputStream(outFile)));
- } catch (FileNotFoundException e1) {
- e1.printStackTrace();
- }
- try {
- t.process(dataMap, out);
- } catch (TemplateException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- public 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 String saveFile() {
- String nowpath = System.getProperty("user.dir");
- String path = nowpath.replace("bin", "webapps");
- path += "\\"+"TestWeb"+"\\"+"word";
- File tmp = new File(path);
- if (!tmp.exists()) {
- tmp.mkdirs();
- }
- return path;
- }
- }
6.模版的制作:
1).新建word文档,内容如下图:
2).把word文档另存为Word 2003 XML 文档,打开内容,如下图:
在<w:tr>之前<#list list as list>,在</w:tr>之后加</#list>,如果不循环,不需要加。接在把图片生产的一大串字符改成${image},试情况改此文件的编码。
3).把修改好的xml后缀改为ftl。模版做好,放在指定位置即可。跑完程序后,生产如下word:
大功告成!有什么问题,大家一起讨论!
相关推荐
本项目涉及的关键技术是利用ECharts生成统计图,然后自动保存这些图像到服务器,最后结合Freemarker模板引擎生成包含图片和循环表格的Word文档。 ECharts是一款由百度开发的开源数据可视化库,它提供了丰富的图表...
在Word文档中生成统计图是一项常见的需求,尤其在数据分析和报告制作时。本篇文章将深入探讨两种方法,教你如何利用FreeMarker来实现这一功能。 ### 一、生成图片在客户端放入Word文档 1. **生成统计图**: 首先,...
在这个"freemarkerdemo生成word插入图片"的示例中,我们主要探讨如何利用Freemarker来创建Word文档,并且将图片集成到这些文档中。这个过程涉及到几个关键的技术点: 1. **Freemarker基础知识**:Freemarker是一个...
在生成Word文档时,我们使用Apache POI创建一个Word文档对象,接着创建表格并添加行。在每个单元格中,我们利用POI API插入图片,图片数据来自FreeMarker处理后的结果。FreeMarker将图片的二进制数据转换成`...
4. 使用JFreeChart生成图表并保存为图片文件。 5. 在生成的Word文档中,确保图表图像正确显示。 最后,压缩包中的"FreemarkerWord"可能包含了以下文件: - 一个或多个Freemarker模板文件(.ftl),定义了Word文档的...
传统的做法可能是将图片作为二进制流保存到服务器,然后在Word文档中引用这个URL。但这种方式在离线或安全性要求较高的场景下可能不适用。为了解决这个问题,项目采用了将图片转换为Base64编码字符串的方式。 Base...
总结,使用Java FreeMarker导出包含多张图片的Word文档,需要结合Apache POI库,创建合适的模板,处理图片数据,并通过FreeMarker将模板与数据合并。这个过程涉及到文件操作、模板引擎的理解以及对Word文档结构的...
以上就是FreeMarker与Apache POI结合生成Word文档并插入图片的基本流程。这种组合可以灵活地创建复杂的动态文档,适应各种需求,例如报告生成、批量文档定制等。开发者可以根据具体需求调整模板设计和数据模型,以...
在FreeMarker模板中,你需要使用Apache POI的API将Base64编码的图片插入到Word文档中。这涉及到创建`WPicture`对象,并将它添加到`Drawing`对象中。这个过程比较复杂,通常需要对Word文档的XML结构有深入理解。 总...
5. **保存文件**:最后,你需要保存生成的Word文档到本地或服务器上,这可以通过Java的文件操作API完成。 关于标签中的"freemarker",它强调了Freemarker作为模板引擎的角色;"模板"指的是用于生成Word文档的XML...
freemarker根据模板ftl生成word,pdf格式转word,pdf指定位置插入图片
综上所述,FreeMarker生成Word文件涉及到Java编程、模板引擎使用、数据模型构建以及可能的第三方库(如Apache POI)的集成。通过熟练掌握这些知识点,开发者可以创建灵活且动态的Word文档生成系统。
通过Java代码,我们可以将业务数据绑定到这些模板上,FreeMarker引擎会自动处理模板和数据的合并,生成Word文档。 使用UTF-8编码是该项目的一个关键点。在处理中文字符时,确保文件编码正确至关重要,否则可能会...
Springboot项目中: 1. 使用Apache POI 3.9 自定义样式导出Excel文件...2. 使用freemarker动态生成word .doc文档(带图片Word以及复杂格式word) 详细说明见个人博客及 github: https://github.com/DuebassLei/excel-poi
在这个步骤中,我们可以学习到如何使用 Freemarker 库来填充数据到模板中,并生成最终的 Word 文档。 在 Demo 中,我们可以看到,首先,我们需要引入 Freemarker 库的相关类,然后创建一个 Configuration 对象,并...
然后,使用Freemarker的`Template`类来解析模板并合并数据,最后将生成的Word文档输出到文件系统。 5. **生成Word文档**: Freemarker可以生成多种类型的输出,包括Word文档。生成Word文档时,它会将模板解析为...
### 使用FreeMarker生成Word文档 1. **配置FreeMarker**:首先,需要在项目中引入FreeMarker的依赖,例如通过Maven或Gradle添加对应的依赖库。然后,配置FreeMarker的环境,包括设置模板目录、缓存策略等。 2. **...
本篇文章将深入探讨如何使用FreeMarker模板引擎来生成包含图片和动态数据表的Word文档,尤其注重动态行和动态列的处理。 FreeMarker是一个强大的模板语言,用于生成文本输出,如HTML、XML、Word文档等。它与Java...
Java中使用FreeMarker生成PDF合同文件的过程主要包括配置FreeMarker环境、创建数据模型、解析模板、生成PDF以及添加图片盖章。通过结合FreeMarker的灵活性和Flying Saucer的转换能力,我们可以方便地将动态生成的...
大致的思路是先用office2003或者2007编辑好word的样式,然后另存为xml,将xml翻译为FreeMarker模板,最后用java来解析FreeMarker模板并输出‘.doc’ word文档。经测试这样方式生成的word文档完全符合office标准,...