java利用 aspose-words Word或Excel 转Pdf(无水印、页数限制)

java利用 aspose-words Word或Excel 转Pdf(无水印、页数限制)1:首先需要引入相关的jarword转pdf需要引入aspose-words-15.8.0-jdk16.jar下载JAR包Wordhttp://note.youdao.com/noteshare?id=1e73ab1c91abad338271d50a881165c2excel转pdf需要引入aspose-cells-8.5.2.jarExcelhttp://note….

大家好,又见面了,我是你们的朋友全栈君。

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>

用浏览器打开,点击链接

java利用 aspose-words Word或Excel 转Pdf(无水印、页数限制)

java利用 aspose-words Word或Excel 转Pdf(无水印、页数限制)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141636.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SpringBoot 面试题及答案

    SpringBoot 面试题及答案文章目录1.什么是SpringBoot?2.SpringBoot有哪些优点?3.什么是JavaConfig?4.如何重新加载SpringBoot上的更改,而无需重新启动服务器?5.SpringBoot中的监视器是什么?6.如何在SpringBoot中禁用Actuator端点安全性?7.如何在自定义端口上运行SpringBoot应用程序?8.什么是YAML?9.如何实现SpringBoot应用程序的安全性?10.如何集成SpringBoot和Activ

    2022年5月21日
    38
  • 队列的顺序存储结构之循环队列

    队列的顺序存储结构之循环队列一、队列的定义队列(queue)是只允许在一端进行插入操作,而在另一端进行删除操作的线性表。队列是一种先进先出(FirstInFirstOut)的线性表,简称FIFO。允许插入的一端称为队尾,允许删除的一端称为队头。如图所示:二、循环队列的引出为了避免当队中只剩一个元素的时候,队头队尾重合使处理变得麻烦。所以我们引入两个指针,front指针指向队头元素,rear指针指向队尾元素…

    2022年5月22日
    36
  • gcc命令的常用选项_curl常用命令及参数

    gcc命令的常用选项_curl常用命令及参数gcc是GUNC和C++编译器,我们通常使用GCC时,编译器会依次做如下工作:preprocess(预处理),compilation(编译),assembly(汇编),link(链接)。gcc提供了一些选项参数能够让编译器停在某个过程(如编译过程)。

    2022年10月13日
    0
  • Shell:export命令

    Shell:export命令https://www.cnblogs.com/tinywan/p/7224011.html一、Windows环境变量  1、在Windows系统下,很多软件安装都需要配置环境变量,比如安装jdk,如果不配置环境变量,在非软件安装的目录下运行javac命令,将会报告找不到文件,类似的错误。  2、那么什么是环境变量?简单说,就是指定一个目录,运行软件的时候,相关的程序将会按照该目录寻找相关文件。设置变量对于一般人最实用的功能就是:不用拷贝某些dll文件到系统目录中了,而path

    2022年9月7日
    0
  • Oracle 更改表名称的几种方式

    Oracle 更改表名称的几种方式1:使用命令直接修改(推荐)ALTERTABLEold_table_nameRENAMETOnew_table_name;(大写为系统命令)2:使用rename修改 SQL>selecttnamefromtab;TNAME——————————TESTSQL>renametesttotemp;T

    2022年5月16日
    57
  • 网页中图片去色问题是什么_网页问题

    网页中图片去色问题是什么_网页问题网页中图片去色问题网页中经常需要一种js效果,就是鼠标经过某张图片,图片去色。为了不加载两张图片(一张彩色和一张灰色),在网上找到了一些方法。方案一:使用grayscale.js可以使用grayscale.js来实现图片的去色,但是有个缺点就是它可以实现鼠标经过图片去色,但是实现不了鼠标移开之后,图片恢复颜色。使用demo:window.onload=function(

    2022年10月6日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号