java利用 aspose-words Word或Excel 轉Pdf(無水印、頁數限制)

1:首先需要引入相關的jar

 word轉pdf需要引入 aspose-words-15.8.0-jdk16.jar

下載JAR包 
Word 
http://note.youdao.com/noteshare?id=1e73ab1c91abad338271d50a881165c2

 excel轉pdf需要引入aspose-cells-8.5.2.jar

Excel 
http://note.youdao.com/noteshare?id=f75d87445106ea6ca6b54cfa58bc4fb2

注意:因爲aspose-words直接添加依賴,下載不下來或者不好使,所以需要下載jar包然後配置到本地maven倉庫(使用命令行);

mvn install:install-file -Dfile=D:\aspose-words-15.8.0-jdk16.jar -DgroupId=com.Jcraft -DartifactId=aspose-words  -Dversion=1.25 -Dpackaging=jar

mvn install:install-file -Dfile=D:\aspose-cells-8.5.2.jar -DgroupId=com.Jcraft -DartifactId=aspose-cells  -Dversion=1.25 -Dpackaging=jar

再配置到pom中:

<dependency>
    <groupId>com.jcraft</groupId>
    <artifactId>aspose-words</artifactId>
    <version>1.25</version>
</dependency>

<dependency>
    <groupId>com.jcraft</groupId>
    <artifactId>aspose-cells</artifactId>
    <version>1.25</version>
</dependency>

2:引入License.xml文件(備註:此License文件只能破解Word版本)

將其放入WEB-INF/classes/文件目錄下,優化後可以自定義位置。具體看代碼

<License>
<Data>
<Products>
<Product>Aspose.Total for Java</Product>
<Product>Aspose.Words for Java</Product>
</Products>
<EditionType>Enterprise</EditionType>
<SubscriptionExpiry>20991231</SubscriptionExpiry>
<LicenseExpiry>20991231</LicenseExpiry>
<SerialNumber>8bfe198c-7f0c-4ef8-8ff0-acc3237bf0d7</SerialNumber>
</Data>
<Signature>sNLLKGMUdF0r8O1kKilWAGdgfs2BvJb/2Xp8p5iuDVfZXmhppo+d0Ran1P9TKdjV4ABwAgKXxJ3jcQTqE/2IRfqwnPf8itN8aFZlV3TJPYeD3yWE7IT55Gz6EijUpC7aKeoohTb4w2fpox58wWoF3SNp6sK6jDfiAUGEHYJ9pjU=</Signature>
</License>

注意:沒有測試這個licence,報錯:

java.lang.NullPointerException: stream
	at com.aspose.words.License.setLicense(Unknown Source)
	at com.dxl.core.PdfUtil.getLicense(PdfUtil.java:22)
	at com.dxl.core.PdfUtil.excel2pdf(PdfUtil.java:56)
	at com.dxl.core.PdfUtil.main(PdfUtil.java:82)

註釋掉代碼:(會有水印,還會有頁數限制!!!)

//Word方法中的 
if (!getLicense()) { // 驗證License 若不驗證則轉化出的pdf文檔會有水印產生
            return;
        }

//Excel方法中的 
 if (!getLicense()) { // 驗證License 若不驗證則轉化出的pdf文檔會有水印產生
            return;
        }

3:java代碼編寫

package com.dxl.core;

import com.aspose.cells.Workbook;
import com.aspose.words.Document;
import com.aspose.words.License;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;

/**
 * <b>
 * </b><br><br><i>Description</i> :
 * <br><br>Date: 2019/11/12 ${time}    <br>Author : dxl
 */
public class PdfUtil {
    private static boolean getLicense() {
        boolean result = false;
        try {
//            InputStream is = PdfUtil.class.getClassLoader().getResourceAsStream("license.xml"); // license.xml應放在..\WebRoot\WEB-INF\classes路徑下
//通過下面直接配置licence路徑更方便,路徑可以當參數、或者配置在配置文件中,自行修改
InputStream is =  new FileInputStream("C:\\Users\\00\\Desktop\\baogao\\license.xml");
            License aposeLic = new License();
            aposeLic.setLicense(is);
            result = true;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }

    /**
     * @param wordPath 需要被轉換的word全路徑帶文件名
     * @param pdfPath 轉換之後pdf的全路徑帶文件名
     */
    public static void doc2pdf(String wordPath, String pdfPath) {
        if (!getLicense()) { // 驗證License 若不驗證則轉化出的pdf文檔會有水印產生
            return;
        }
        try {
            long old = System.currentTimeMillis();
            File file = new File(pdfPath); //新建一個pdf文檔
            FileOutputStream os = new FileOutputStream(file);
            Document doc = new Document(wordPath); //Address是將要被轉化的word文檔
            doc.save(os, com.aspose.words.SaveFormat.PDF);//全面支持DOC, DOCX, OOXML, RTF HTML, OpenDocument, PDF, EPUB, XPS, SWF 相互轉換
            long now = System.currentTimeMillis();
            os.close();
            System.out.println("共耗時:" + ((now - old) / 1000.0) + "秒"); //轉化用時
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * @param excelPath 需要被轉換的excel全路徑帶文件名
     * @param pdfPath 轉換之後pdf的全路徑帶文件名
     */
    public static void excel2pdf(String excelPath, String pdfPath) {
        if (!getLicense()) { // 驗證License 若不驗證則轉化出的pdf文檔會有水印產生
            return;
        }
        try {
            long old = System.currentTimeMillis();
            Workbook wb = new Workbook(excelPath);// 原始excel路徑
            FileOutputStream fileOS = new FileOutputStream(new File(pdfPath));
            wb.save(fileOS, com.aspose.cells.SaveFormat.PDF);
            fileOS.close();
            long now = System.currentTimeMillis();
            System.out.println("共耗時:" + ((now - old) / 1000.0) + "秒"); //轉化用時
        } catch (Exception e) {
            e.printStackTrace();
        }
    }



    public static void main(String[] args) {

        //word 和excel 轉爲pdf
        String filePaths="E:\\myGiteeProject\\mygenerator\\src\\main\\resources\\testdocx\\demo3.docx";
        String fileName="zsqexcel80";
        String pdfPath="E:\\myGiteeProject\\mygenerator\\src\\main\\resources\\testdocx\\"+fileName+".pdf";
//        doc2pdf(filePaths, pdfPath);//filePaths需要轉換的文件位置 pdfPath爲存儲位置
        String excel2pdf="E:\\myGiteeProject\\mygenerator\\src\\main\\resources\\testdocx\\cells.xlsx";
        excel2pdf(excel2pdf,pdfPath);
    }
}

4.瀏覽器預覽pdf(寫一個html,如下)

<a href="E:\myGiteeProject\mygenerator\src\main\resources\testdocx\zsqexcel78.pdf">PDF預覽連接--路徑</a>

用瀏覽器打開,點擊鏈接

發佈了64 篇原創文章 · 獲贊 6 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章