我是docx4j的新手。我正在使用docx4j创建新的.docx文件。在将项目从eclipse部署到tomcat服务器时,我的代码完美运行。但它不适用于实时服务器。以下是我的代码:
String html = "<html><head><meta charset=\"UTF-8\"><title></title>"
+ "</head><body>"
+ "<div><div style='width:100%;display:inline; text-align:right;'>मितिः "
+new Date()+"</div><div class=\"block p-top-2\" style='display:block; float:left;'>"
+ "च.नं. "
+ "<span style=\"display: inline !important;\">"+10088+" - "+73 + "/" + 74
+ "</span></div></div></body></html>";
WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.createPackage();
AlternativeFormatInputPart afiPart = new AlternativeFormatInputPart(new PartName("/hw.html"));
afiPart.setBinaryData(html.getBytes());
afiPart.setContentType(new ContentType("text/html"));
Relationship altChunkRel = wordMLPackage.getMainDocumentPart().addTargetPart(afiPart);
afiPart.registerInContentTypeManager();
CTAltChunk ac = Context.getWmlObjectFactory().createCTAltChunk();
ac.setId(altChunkRel.getId() );
wordMLPackage.getMainDocumentPart().addObject(ac);
wordMLPackage.getContentTypeManager().addDefaultContentType("html", "text/html;charset=UTF-8");
wordMLPackage.save(new File("created_doc.docx"));
我正在使用Tomcat和Spring Framework.Project使用maven创建并部署在Windows Server 2012 r2上。
答案 0 :(得分:1)
我怀疑这可能是问题所在:
afiPart.setBinaryData(html.getBytes());
这将使用平台默认编码 - 在本地计算机和服务器之间可能明显不同。我强烈建议您始终指定编码。如果您想要UTF-8,请使用:
afiPart.setBinaryData(html.getBytes(StandardCharsets.UTF_8));