e-iceblue spire.doc for java的引入与使用
为了解决freeMarker导出的word是xml形式,但是手机打不开需要转换成正常的docx文件的问题
1.在pom文件下写入spire.doc的依赖
<dependency>
<groupId>e-iceblue</groupId>
<artifactId>spire.doc</artifactId>
<version>11.1.1</version>
</dependency>
2.然后在该pom文件的存储库集合中加入这个存储库(如果不加这个会下载不下来的哦)
<repositories>
<repository>
<id>com.e-iceblue</id>
<url>http://repo.e-iceblue.cn/repository/maven-public/</url>
</repository>
</repositories>
3.然后点击maven旋转按钮
4. 转换核心代码
//这里开始将xml文件转换成真正的docx的形式
String tempUrl = tmpFile.getPath();//tmpFile是临时文件 即File 的形式
Document doc = new Document();
doc.loadFromFile(tempUrl);
String transDocxName = tempUrl.replace(".doc", ".docx");
doc.saveToFile(transDocxName, FileFormat.Docx);
XmlDocToDocx.restWord(transDocxName);
File docxFile = new File(transDocxName);
5.其中restWord方法是自己搜索写的,不使用这个方法的话会有水印
/**
* 使用spire.Doc 会出现一个水印可以通过这个方法去除水印
* @param docFilePath
*/
public static void restWord(String docFilePath) {
try (FileInputStream in = new FileInputStream(docFilePath)) {
XWPFDocument doc = new XWPFDocument(OPCPackage.open(in));
List<XWPFParagraph> paragraphs = doc.getParagraphs();
if (paragraphs.size() < 1) {
return;
}
XWPFParagraph firstParagraph = paragraphs.get(0);
if (firstParagraph.getText().contains("Spire.Doc")) {
doc.removeBodyElement(doc.getPosOfParagraph(firstParagraph));
}
OutputStream out = new FileOutputStream(docFilePath);
doc.write(out);
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
然后就可以按照正常的流传入传入到浏览器导出了!!!
后续发现这样子导出实在是太慢了,所以请看我后面写的这篇文章
传送门