700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > java freemarker 导出富文本到Word文档

java freemarker 导出富文本到Word文档

时间:2023-11-09 17:24:42

相关推荐

java freemarker 导出富文本到Word文档

最近一直在加班 导致看到代码就想吐 今天抽出时间来记录一下 用freemaker导出富文本信息

之前使用freemaker导出图片等信息时 使用的是xml方式,不明白的 可以看freemaker生成Word文档(图片、超链接)

由于xml方式 不识别<p><b>等这种HTML标签,所以只能使用mht方式来解决,话不多说 干起来!

我是看到前辈的文章才 有所启发!

1.准备好模板

这里我要强调一下 模板里面插入图片时 不要使用插入->上传图片,这样会是超链接的形式,里面使用的绝对路径 当把文档转给他人时 图片显示不出来

这种上传图片方式是错误的 应该直接复制图片到Word文档中

此时,模板已生成

将模板内容替换为占位符(${})形式 此时建议保留图片 这样分析文档结构 方便些

后另存为 单个文件网页(*.mht,*.mhtml)文件,于是生成一个.mht文件 最后调整后缀名为ftl文件

2.ftl占位符修改

全文检索gb2312/utf-8把他改成utf-8,同时需要加上3D前缀${}占位符 中间会生成一些其他字符 需要将其他扰乱信息去掉 只保留占位符记住这三处标识【NextPart_ 和 Content-Location】 这里文档 全都是一样的 所以在生成图片base64定义时 也要保持一致

添加 ${imagesBase64String!""} 标识 在folHlink下面添加 该标识 存放图片base64信息

添加 ${imagesXmlHrefString!""} 标识 在filelist.xml 上面添加 该标识 存放图片base64的链接信息去掉之前 保留的图片信息对应代码

其实添加的${imagesBase64String}和${imagesXmlHrefString}标识 就是 首先定义一个图片的base64,然后在下面引用,随后在正文中 直接调用图片的引用即可。

不明白的 可以看一下 其他图片的生成方式 【上面建议保留一张图片, 就是为了方便文档结构中图片的分析】

例如:看一下图片 image004.jpg

图片base64的定义图片链接的引用图片的显示 调用图片链接的引用 <v:shape>xxxxx</v:shape>及后面的<img/> 这些是页面显示的图片 需要动态生成

此时 报告的模板修改 已经完成,下面开始上代码

因为 本项目的富文本存储的形式 为base64,而不是存储图片的地址,所以需要先根据base64生成图片 在进行操作。

测试数据

Map<String, Object> dataMap = new HashMap<>();List<String> photoNameList=new ArrayList<>();String handledBase64Block = ""; //base64String xmlimaHref = ""; //图片链接//模拟数据StringBuilder sb = new StringBuilder();sb.append("<div>");sb.append("<p>概况</p><p><br></p><p><img src=\"\"></p><p><br></p><p><span style=\"color: rgb(230, 0, 0);\" class=\"ql-size-large\">去掉ip校验</span></p>");sb.append("<p><span style=\"color: rgb(77, 77, 77);\">利用</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">来解析带</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">图片的富文本,思路是:</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板另存为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">mht</code><span style=\"color: rgb(77, 77, 77);\">格式,再修改后缀为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">ftl</code><span style=\"color: rgb(77, 77, 77);\">。将</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">字符串的图片,填充到制作的模板上。</span></p><p><span style=\"color: rgb(77, 77, 77);\">首先我们需要填充的</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板如下:</span></p>");sb.append("</div>");RichHtmlHandler test1handler = new RichHtmlHandler(sb.toString());test1handler.setDocSrcLocationPrex("file:///C:/5181FBD1");test1handler.setDocSrcParent("file3105.files");test1handler.setNextPartId("01D73090.2D92D3A0");test1handler.setShapeidPrex("_x56fe__x7247__x0020");test1handler.setSpidPrex("_x0000_i");test1handler.setTypeid("#_x0000_t75");try {test1handler.handledHtml(false,filePath);} catch (IOException e) {e.printStackTrace();}if (test1handler.getDocBase64BlockResults() != null&& test1handler.getDocBase64BlockResults().size() > 0) {for (String item : test1handler.getDocBase64BlockResults()) {handledBase64Block += item + "\n";}}if (test1handler.getXmlImgRefs() != null&& test1handler.getXmlImgRefs().size() > 0) {for (String item : test1handler.getXmlImgRefs()) {xmlimaHref += item + "\n";}}String bodyBlock = test1handler.getHandledDocBodyBlock();dataMap.put("test1",bodyBlock);StringBuilder sbTest2 = new StringBuilder();sbTest2.append("<div>");sbTest2.append("<img src=\"\">");sbTest2.append("<p><span style=\"color: rgb(77, 77, 77);\">利用</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">来解析带</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">图片的富文本,思路是:</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板另存为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">mht</code><span style=\"color: rgb(77, 77, 77);\">格式,再修改后缀为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">ftl</code><span style=\"color: rgb(77, 77, 77);\">。将</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">字符串的图片,填充到制作的模板上。</span></p><p><span style=\"color: rgb(77, 77, 77);\">首先我们需要填充的</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板如下:</span></p>");sbTest2.append("<span>中国梦,幸福梦!</span>");sbTest2.append("</div>");RichHtmlHandler test2handler = new RichHtmlHandler(sbTest2.toString());test2handler.setDocSrcLocationPrex("file:///C:/5181FBD1");test2handler.setDocSrcParent("file3105.files");test2handler.setNextPartId("01D73090.2D92D3A0");test2handler.setShapeidPrex("_x56fe__x7247__x0020");test2handler.setSpidPrex("_x0000_i");test2handler.setTypeid("#_x0000_t75");try {test2handler.handledHtml(false,filePath);} catch (IOException e) {e.printStackTrace();}String eventCoursehandlerBodyBlock = test2handler.getHandledDocBodyBlock();dataMap.put("test2",eventCoursehandlerBodyBlock);if (test2handler.getDocBase64BlockResults() != null&& test2handler.getDocBase64BlockResults().size() > 0) {for (String item : test2handler.getDocBase64BlockResults()) {handledBase64Block += item + "\n";}}if (test2handler.getXmlImgRefs() != null&& test2handler.getXmlImgRefs().size() > 0) {for (String item : test2handler.getXmlImgRefs()) {xmlimaHref += item + "\n";} }dataMap.put("imagesBase64String", handledBase64Block);dataMap.put("imagesXmlHrefString", xmlimaHref);

HTML解析

public class RichHtmlHandler {private Document doc = null;private String html;private String docSrcParent = "";private String docSrcLocationPrex = "";private String nextPartId;private String shapeidPrex;private String spidPrex;private String typeid;private String handledDocBodyBlock;private List<String> docBase64BlockResults = new ArrayList<String>();private List<String> xmlImgRefs = new ArrayList<String>();private List<String> photoNameList=new ArrayList<>(); //存储临时图片 方便后续删除public List<String> getPhotoNameList() {return photoNameList;}public String getDocSrcLocationPrex() {return docSrcLocationPrex;}public void setDocSrcLocationPrex(String docSrcLocationPrex) {this.docSrcLocationPrex = docSrcLocationPrex;}public String getNextPartId() {return nextPartId;}public void setNextPartId(String nextPartId) {this.nextPartId = nextPartId;}public String getHandledDocBodyBlock() {String raw= WordHtmlGeneratorHelper.string2Ascii(doc.getElementsByTag("body").html());return raw.replace("=3D", "=").replace("=", "=3D");}public String getRawHandledDocBodyBlock() {String raw= doc.getElementsByTag("body").html();return raw.replace("=3D", "=").replace("=", "=3D");}public List<String> getDocBase64BlockResults() {return docBase64BlockResults;}public List<String> getXmlImgRefs() {return xmlImgRefs;}public String getShapeidPrex() {return shapeidPrex;}public void setShapeidPrex(String shapeidPrex) {this.shapeidPrex = shapeidPrex;}public String getSpidPrex() {return spidPrex;}public void setSpidPrex(String spidPrex) {this.spidPrex = spidPrex;}public String getTypeid() {return typeid;}public void setTypeid(String typeid) {this.typeid = typeid;}public String getDocSrcParent() {return docSrcParent;}public void setDocSrcParent(String docSrcParent) {this.docSrcParent = docSrcParent;}public String getHtml() {return html;}public void setHtml(String html) {this.html = html;}public RichHtmlHandler(String html) {doc = Jsoup.parse(wrappHtml(html));}public void re_init(String html){doc=null;doc = Jsoup.parse(wrappHtml(html));docBase64BlockResults.clear();xmlImgRefs.clear();}/*** @Description: 获得已经处理过的HTML文件* @param @return* @return String* @throws IOException * @throws*/public void handledHtml(boolean isWebApplication,String filePath)throws IOException {List<String> photoNames=new ArrayList<>();Elements imags = doc.getElementsByTag("img");if (imags == null || imags.size() == 0) {// 返回编码后字符串return;}for (Element item : imags) {// 把文件取出来String src = item.attr("src");File imageFile = null;String fileTypeName="jpg";String uuid = UUIDUtils.get32UUID(); //图片的UUIDString base64Content="";String srcRealPath = "";if(src.contains("base64")){//src="D:\\1.png";//将base64转换为图片file 存储到本地路径String[] split = src.split("base64,");if (split != null && split.length == 2) {if(split[0].contains("/")){fileTypeName=split[0].substring(split[0].indexOf("/")+1,split[0].length()-1);}base64Content= split[1];String photoName=uuid+"."+fileTypeName;Base64ToFileUtil.base64ToFile(filePath,base64Content,photoName);imageFile=new File(filePath+photoName);if(imageFile.exists()){photoNames.add(photoName);srcRealPath=filePath+photoName;item.attr("src",srcRealPath);}}}String imageFielShortName = imageFile.getName();String docFileName = "image" + uuid + "."+ fileTypeName;String srcLocationShortName = docSrcParent + "/" + docFileName;String styleAttr = item.attr("style"); // 样式int imageHeight = 0;int imageWidth = 0;// 得到文件的word mht的body块String handledDocBodyBlock = WordImageConvertor.toDocBodyBlock(srcRealPath,imageFielShortName, imageHeight, imageWidth,styleAttr,srcLocationShortName, shapeidPrex, spidPrex, typeid);item.parent().append(handledDocBodyBlock);item.remove();// 去替换原生的html中的imagString contextLoacation = docSrcLocationPrex + "/" + docSrcParent+ "/" + docFileName;String docBase64BlockResult = WordImageConvertor.generateImageBase64Block(nextPartId, contextLoacation,fileTypeName, base64Content);docBase64BlockResults.add(docBase64BlockResult);String imagXMLHref = "<o:File HRef=3D\"" + docFileName + "\"/>";xmlImgRefs.add(imagXMLHref);}photoNameList=photoNames;}private String getStyleAttrValue(String style, String attributeKey) {if (StringUtils.isEmpty(style)) {return "";}// 以";"分割String[] styleAttrValues = style.split(";");for (String item : styleAttrValues) {// 在以 ":"分割String[] keyValuePairs = item.split(":");if (attributeKey.equals(keyValuePairs[0])) {return keyValuePairs[1];}}return "";}private String wrappHtml(String html){// 因为传递过来都是不完整的docStringBuilder sb = new StringBuilder();sb.append("<html>");sb.append("<body>");sb.append(html);sb.append("</body>");sb.append("</html>");return sb.toString();}}

Word导出

public class WordGeneratorWithFreemarker { private static Configuration configuration = null; private static final String FTL_FP = "/template/"; //模板路径static { configuration = new Configuration(Configuration.VERSION_2_3_23); configuration.setDefaultEncoding("utf-8"); configuration.setClassicCompatible(true);configuration.setClassForTemplateLoading(WordGeneratorWithFreemarker.class, FTL_FP);} private WordGeneratorWithFreemarker() { } public static void createDoc(Map<String, Object> dataMap, String templateName, OutputStream out) throws TemplateNotFoundException, MalformedTemplateNameException, ParseException, IOException {Template t = configuration.getTemplate(templateName);WordHtmlGeneratorHelper.handleAllObject(dataMap);Writer w=null;try { // 这个地方不能使用FileWriter因为需要指定编码类型否则生成的Word文档会因为有无法识别的编码而无法打开 w = new OutputStreamWriter(out);t.process(dataMap, w);} catch (Exception ex) { ex.printStackTrace(); throw new RuntimeException(ex); }finally {if(w!=null){w.close();}}return ; }}

网页导出

public class WordHtmlGeneratorHelper {/** * @Description: 将字符换成3Dus-asci,十进制Accsii码* @param @param source* @param @return * @return String * @throws*/public static String string2Ascii(String source){if(source==null || source==""){return null;}StringBuilder sb=new StringBuilder();char[] c=source.toCharArray();for(char item : c){String itemascii="";if(item>=19968 && item<40623){itemascii=itemascii="&#"+(item & 0xffff)+";";}else{itemascii=item+"";}sb.append(itemascii);}return sb.toString();}/** * @Description: 将object的所有属性值转成成3Dus-asci编码值* @param @param object* @param @return * @return T * @throws*/public static <T extends Object> T handleObject2Ascii(final T toHandleObject){class myFieldsCallBack implements FieldCallback{@Overridepublic void doWith(Field f) throws IllegalArgumentException,IllegalAccessException {if(f.getType().equals(String.class)){//如果是字符串类型f.setAccessible(true);String oldValue=(String)f.get(toHandleObject);if(!StringUtils.isEmpty(oldValue)){f.set(toHandleObject, string2Ascii(oldValue));}//f.setAccessible(false);}}}ReflectionUtils.doWithFields(toHandleObject.getClass(), new myFieldsCallBack());return toHandleObject;}public static <T extends Object> List<T> handleObjectList2Ascii(final List<T> toHandleObjects){for (T t : toHandleObjects) {handleObject2Ascii(t);}return toHandleObjects;}public static void handleAllObject(Map<String, Object> dataMap){//去处理数据for (Map.Entry<String, Object> entry : dataMap.entrySet()){Object item=entry.getValue();//判断object是否是primitive type if(isPrimitiveType(item.getClass())){if(item.getClass().equals(String.class)){item=WordHtmlGeneratorHelper.string2Ascii((String)item);entry.setValue(item);}}else if(isCollection(item.getClass())){for (Object itemobject : (Collection)item) {WordHtmlGeneratorHelper.handleObject2Ascii(itemobject);}}else{WordHtmlGeneratorHelper.handleObject2Ascii(item);}}}public static String joinList(List<String> list,String join ){StringBuilder sb=new StringBuilder();for (String t : list) {sb.append(t);if(!StringUtils.isEmpty(join)){sb.append(join);}}return sb.toString();} private static boolean isPrimitiveType(Class<?> clazz){return clazz.isEnum() ||CharSequence.class.isAssignableFrom(clazz) ||Number.class.isAssignableFrom(clazz) ||Date.class.isAssignableFrom(clazz);}private static boolean isCollection(Class<?> clazz){return Collection.class.isAssignableFrom(clazz);}}

图片转换

public class WordImageConvertor {/*** @param @param imageSrc 文件路径* @param @return* @return String* @throws IOException* @throws* @Description: 将图片转换成base64编码的字符串* @author:LiaoFei* @date:-3-28 上午11:22:26*/public static String imageToBase64(String imageSrc) throws IOException {//判断文件是否存在File file = new File(imageSrc);if (!file.exists()) {throw new FileNotFoundException("文件不存在!");}StringBuilder pictureBuffer = new StringBuilder();FileInputStream input = new FileInputStream(file);ByteArrayOutputStream out = new ByteArrayOutputStream();//读取文件Base64 base64 = new Base64();BASE64Encoder encoder = new BASE64Encoder();byte[] temp = new byte[1024];for (int len = input.read(temp); len != -1; len = input.read(temp)) {out.write(temp, 0, len);}pictureBuffer.append(new String(base64.encodeBase64Chunked(out.toByteArray())));out.close();input.close();return pictureBuffer.toString();}public static String toDocBodyBlock(String imageFilePath,String imageFielShortName,int imageHeight,int imageWidth,String imageStyle,String srcLocationShortName,String shapeidPrex, String spidPrex, String typeid) {//shapeid//mht文件中针对shapeid的生成好像规律,其内置的生成函数没法得知,但是只要保证其唯一就行//这里用前置加32位的uuid来保证其唯一性。String shapeid = shapeidPrex;shapeid += UUIDUtils.get32UUID();//spid ,同shapeid处理String spid = spidPrex;spid += UUIDUtils.get32UUID();/*<!--[if gte vml 1]><v:shape id=3D"_x56fe__x7247__x0020_0" o:spid=3D"_x0000_i10=26"type=3D"#_x0000_t75" alt=3D"725017921264249223.jpg" style=3D'width:456.7=5pt;height:340.5pt;visibility:visible;mso-wrap-style:square'><v:imagedata src=3D"file9462.files/image001.jpg" o:title=3D"725017921264=249223"/></v:shape><![endif]--><![if !vml]><img width=3D609 height=3D454src=3D"file9462.files/image002.jpg" alt=3D725017921264249223.jpg v:shapes==3D"_x56fe__x7247__x0020_0"><![endif]>*/StringBuilder sb1 = new StringBuilder();sb1.append(" <!--[if gte vml 1]>");sb1.append("<v:shape id=3D\"" + shapeid + "\"");sb1.append("\n");sb1.append(" o:spid=3D\"" + spid + "\"");sb1.append(" type=3D\"" + typeid + "\" alt=3D\"" + imageFielShortName + "\"");sb1.append("\n");sb1.append(" style=3D' " + generateImageBodyBlockStyleAttr(imageFilePath, imageHeight, imageWidth) + imageStyle + "'");sb1.append(">");sb1.append("\n");sb1.append(" <v:imagedata src=3D\"" + srcLocationShortName + "\"");sb1.append("\n");sb1.append(" o:title=3D\"" + imageFielShortName.split("\\.")[0] + "\"");sb1.append("/>");sb1.append("</v:shape>");sb1.append("<![endif]-->");//以下是为了兼容游览器显示时的效果,但是如果是纯word阅读的话没必要这么做。StringBuilder sb2 = new StringBuilder();sb2.append(" <![if !vml]>");sb2.append("<img width=3D" + imageWidth + " height=3D" + imageHeight +" src=3D\"" + srcLocationShortName + "\" alt=" + imageFielShortName +" v:shapes=3D\"" + shapeid + "\">");sb2.append("<![endif]>");return sb1.toString() + sb2.toString();//return sb1.toString();}/*** @param @param nextPartId* @param @param contextLoacation* @param @param ContentType* @param @param base64Content* @param @return* @return String* @throws* @Description: 生成图片的base4块* @author:LiaoFei* @date:-3-28 下午4:02:05*/public static String generateImageBase64Block(String nextPartId, String contextLoacation,String fileTypeName, String base64Content) {/*--=_NextPart_01D188DB.E436D870Content-Location: file:///C:/70ED9946/file9462.files/image001.jpgContent-Transfer-Encoding: base64Content-Type: image/jpegbase64Content*/StringBuilder sb = new StringBuilder();sb.append("\n");sb.append("\n");sb.append("------=_NextPart_" + nextPartId);sb.append("\n");sb.append("Content-Location: " + contextLoacation);sb.append("\n");sb.append("Content-Transfer-Encoding: base64");sb.append("\n");sb.append("Content-Type: " + getImageContentType(fileTypeName));sb.append("\n");sb.append("\n");sb.append(base64Content);return sb.toString();}private static String generateImageBodyBlockStyleAttr(String imageFilePath, int height, int width) {StringBuilder sb = new StringBuilder();BufferedImage sourceImg;FileInputStream fileInputStream=null;try {fileInputStream = new FileInputStream(imageFilePath);sourceImg = ImageIO.read(fileInputStream);if (height == 0) {height = sourceImg.getHeight();}if (width == 0) {width = sourceImg.getWidth();}} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {if(fileInputStream!=null){try {fileInputStream.close();} catch (IOException e) {e.printStackTrace();}}}System.out.println("图片高度"+height+"图片宽度"+width);if(height>300){height=300;} if(width>500){width=500;}//将像素转化成ptBigDecimal heightValue = new BigDecimal(height * 12 / 16);heightValue = heightValue.setScale(2, BigDecimal.ROUND_HALF_UP);BigDecimal widthValue = new BigDecimal(width * 12 / 16);widthValue = widthValue.setScale(2, BigDecimal.ROUND_HALF_UP);sb.append("height:" + heightValue + "pt;");sb.append("width:" + widthValue + "pt;");sb.append("visibility:visible;");sb.append("mso-wrap-style:square; ");return sb.toString();}private static String getImageContentType(String fileTypeName) {String result = "image/jpeg";///table/http_content_typeif (fileTypeName.equals("tif") || fileTypeName.equals("tiff")) {result = "image/tiff";} else if (fileTypeName.equals("fax")) {result = "image/fax";} else if (fileTypeName.equals("gif")) {result = "image/gif";} else if (fileTypeName.equals("ico")) {result = "image/x-icon";} else if (fileTypeName.equals("jfif") || fileTypeName.equals("jpe")|| fileTypeName.equals("jpeg") || fileTypeName.equals("jpg")) {result = "image/jpeg";} else if (fileTypeName.equals("net")) {result = "image/pnetvue";} else if (fileTypeName.equals("png") || fileTypeName.equals("bmp")) {result = "image/png";} else if (fileTypeName.equals("rp")) {result = "image/vnd.rn-realpix";} else if (fileTypeName.equals("rp")) {result = "image/vnd.rn-realpix";}return result;}}

删除单个文件

public class FolderUtil {//删除单个文件public static boolean deleteFile(String fileName) {File file = new File(fileName);// 如果文件路径所对应的文件存在,并且是一个文件,则直接删除if (file.exists() && file.isFile()) {if (file.delete()) {System.out.println("删除单个文件" + fileName + "成功!");return true;} else {System.out.println("删除单个文件" + fileName + "失败!");return false;}} else {System.out.println("删除单个文件失败:" + fileName + "不存在!");return false;}}}

测试

@GetMapping("/createReport")public void createReport() throws Exception{Map<String, Object> dataMap = new HashMap<>();List<String> photoNameList=new ArrayList<>();String handledBase64Block = ""; //base64String xmlimaHref = ""; //图片链接//模拟数据StringBuilder sb = new StringBuilder();sb.append("<div>");sb.append("<p>概况</p><p><br></p><p><img src=\"\"></p><p><br></p><p><span style=\"color: rgb(230, 0, 0);\" class=\"ql-size-large\">去掉ip校验</span></p>");sb.append("<p><span style=\"color: rgb(77, 77, 77);\">利用</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">来解析带</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">图片的富文本,思路是:</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板另存为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">mht</code><span style=\"color: rgb(77, 77, 77);\">格式,再修改后缀为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">ftl</code><span style=\"color: rgb(77, 77, 77);\">。将</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">字符串的图片,填充到制作的模板上。</span></p><p><span style=\"color: rgb(77, 77, 77);\">首先我们需要填充的</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板如下:</span></p>");sb.append("</div>");RichHtmlHandler test1handler = new RichHtmlHandler(sb.toString());test1handler.setDocSrcLocationPrex("file:///C:/AA89CAB4");test1handler.setDocSrcParent("testReport.files");test1handler.setNextPartId("01D7311D.703BAA50");test1handler.setShapeidPrex("_x56fe__x7247__x0020");test1handler.setSpidPrex("_x0000_i");test1handler.setTypeid("#_x0000_t75");try {test1handler.handledHtml(false,filePath);} catch (IOException e) {e.printStackTrace();}if (test1handler.getDocBase64BlockResults() != null&& test1handler.getDocBase64BlockResults().size() > 0) {for (String item : test1handler.getDocBase64BlockResults()) {handledBase64Block += item + "\n";}}if (test1handler.getXmlImgRefs() != null&& test1handler.getXmlImgRefs().size() > 0) {for (String item : test1handler.getXmlImgRefs()) {xmlimaHref += item + "\n";}}String bodyBlock = test1handler.getHandledDocBodyBlock();dataMap.put("test1",bodyBlock);StringBuilder sbTest2 = new StringBuilder();sbTest2.append("<div>");sbTest2.append("<img src=\"\">");sbTest2.append("<p><span style=\"color: rgb(77, 77, 77);\">利用</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">来解析带</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">图片的富文本,思路是:</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板另存为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">mht</code><span style=\"color: rgb(77, 77, 77);\">格式,再修改后缀为</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">ftl</code><span style=\"color: rgb(77, 77, 77);\">。将</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">base64</code><span style=\"color: rgb(77, 77, 77);\">字符串的图片,填充到制作的模板上。</span></p><p><span style=\"color: rgb(77, 77, 77);\">首先我们需要填充的</span><code style=\"color: rgb(199, 37, 78); background-color: rgb(249, 242, 244);\">word</code><span style=\"color: rgb(77, 77, 77);\">模板如下:</span></p>");sbTest2.append("</div>");RichHtmlHandler test2handler = new RichHtmlHandler(sbTest2.toString());test2handler.setDocSrcLocationPrex("file:///C:/AA89CAB4");test2handler.setDocSrcParent("testReport.files");test2handler.setNextPartId("01D7311D.703BAA50");test2handler.setShapeidPrex("_x56fe__x7247__x0020");test2handler.setSpidPrex("_x0000_i");test2handler.setTypeid("#_x0000_t75");try {test2handler.handledHtml(false,filePath);} catch (IOException e) {e.printStackTrace();}String eventCoursehandlerBodyBlock = test2handler.getHandledDocBodyBlock();dataMap.put("test2",eventCoursehandlerBodyBlock);if (test2handler.getDocBase64BlockResults() != null&& test2handler.getDocBase64BlockResults().size() > 0) {for (String item : test2handler.getDocBase64BlockResults()) {handledBase64Block += item + "\n";}}if (test2handler.getXmlImgRefs() != null&& test2handler.getXmlImgRefs().size() > 0) {for (String item : test2handler.getXmlImgRefs()) {xmlimaHref += item + "\n";}}dataMap.put("time", "-04-14");dataMap.put("imagesBase64String", handledBase64Block);dataMap.put("imagesXmlHrefString", xmlimaHref);photoNameList.addAll(test1handler.getPhotoNameList());photoNameList.addAll(test2handler.getPhotoNameList());String docFilePath = "d:\\createReport.doc";System.out.println(docFilePath);File f = new File(docFilePath);OutputStream out=null;try {out = new FileOutputStream(f);WordGeneratorWithFreemarker.createDoc(dataMap, "testReport.ftl", out);java.lang.System.out.println("图片"+photoNameList);if(photoNameList!=null&&photoNameList.size()>0){for(String photoName:photoNameList){if(photoName!=null&&!"".equals(photoName)){FolderUtil.deleteFile(filePath + photoName);}}}} catch (FileNotFoundException e) {} catch (MalformedTemplateNameException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally {try {if (out != null) {out.close();}} catch (IOException e) {e.printStackTrace();}}}

测试结果 (方便截图 部分数据删除)

【注意】

若是多个富文本 那么需要将imagesBase64String及imagesXmlHrefString 数据进行 累加

如图 上面测试代码 已经是 对这两个信息 进行累加的【对每一个富文本都进行累加 并且最后将imagesBase64String及imagesXmlHrefString 赋值给dataMap】

不足之处,还请多多指教!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。