java+puppeteer实现html转pdf文件

1. puppeteer是一个无头浏览器,可以模拟访问网站或者生成html源文件,并返回pdf流的组件。

2. puppeteer使用需要预先安装nodejs, nodejs具体步骤如下[安装最新版本nodejs即可]:Node.js安装教程_北忆₯的博客-CSDN博客_nodejs安装教程

3. puppeteer安装具体步骤如下:进入cmd控制台,执行如下命令:npm install -g puppeteer

之后会在如图上对应位置生成 puppeteer安装包。

4. 在puppeteer安装包下直接创建如下2个文件,此2个文件为2种实现方式:

方式1:puppeteer.js  ,表示从对应URL处获取信息,并返回pdf流。具体代码如下:

const puppeteer = require('puppeteer');
const options = process.argv;
var address, types;

(async() => {
if(options.length>=4){
    address=options[2];
    types=options[3];
}

const browser = await puppeteer.launch();
const page = await browser.newPage();


const userAgent = "Mozilla/5.0 (Linux; Android 8.1.0; MI 8 Build/OPM1.171019.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/62.0.3202.84 Mobile Safari/537.36";
page.setUserAgent(userAgent);

//await page.setViewport({ width: 1920, height: 1080 });

await page.setViewport({ width: 480, height: 800,isMobile: true}); 

await page.goto(address, {waitUntil: 'networkidle2'});
if(types == 'pdf') {
    const pdf = await page.pdf({path: 'd://page.pdf', format: 'A4'});
    await browser.close();
    process.stdout.write(pdf);
}else {
    await browser.close();
}


})();

 方式2:setContent.js  (window系统使用),表示从html文件获取源文件流,并返回pdf流。具体代码如下:

const puppeteer = require('puppeteer');
var fs = require('fs');
const options = process.argv;
var htmlContent;

(async() => {
htmlFilePath=options[2];

const browser = await puppeteer.launch();
const page = await browser.newPage();


const userAgent = "Mozilla/5.0 (Linux; Android 8.1.0; MI 8 Build/OPM1.171019.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/62.0.3202.84 Mobile Safari/537.36";
page.setUserAgent(userAgent);

//await page.setViewport({ width: 1920, height: 1080 });

await page.setViewport({ width: 480, height: 800,isMobile: true}); 

//const buff2 = Buffer.from(htmlContent, 'base64')
//const htmlContentResult = buff2.toString('utf-8')

var contentHtml = fs.readFileSync(htmlFilePath, 'utf-8');

//await page.goto('file://d:\\test2.html');

await page.setContent(contentHtml);

const pdf = await page.pdf({path: 'page.pdf', format: 'A4'});

await browser.close();

process.stdout.write(pdf);


})();

setContent.js  (linux系统使用)

const puppeteer = require('puppeteer');
var fs = require('fs');
const options = process.argv;
var htmlContent;

(async() => {
    htmlFilePath=options[2];

    const browser = await puppeteer.launch({
        args: ['--no-sandbox', '--disable-setuid-sandbox'],
    });
    const page = await browser.newPage();


    const userAgent = "Mozilla/5.0 (Linux; Android 8.1.0; MI 8 Build/OPM1.171019.011; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/62.0.3202.84 Mobile Safari/537.36";
    page.setUserAgent(userAgent);

//await page.setViewport({ width: 1920, height: 1080 });

    await page.setViewport({ width: 1800, height: 1800});

//const buff2 = Buffer.from(htmlContent, 'base64')
//const htmlContentResult = buff2.toString('utf-8')

    var contentHtml = fs.readFileSync(htmlFilePath, 'utf-8');

//await page.goto('file://d:\\test2.html');

    await page.setContent(contentHtml);

    const pdf = await page.pdf({path: 'page.pdf', fullPage: true});

    await browser.close();

    process.stdout.write(pdf);


})();

3.  puppeteer.js对应的java调用代码如下:

/**
     * html转pdf,直接通过流输出到浏览器
     *
     * @param response    浏览器响应
     * @param fileName    文件名称
     * @param puppeteerjs 要采用哪个js文件执行
     * @param webSiteUrl  要生成pdf/图片的网页
     * @param types       类型  :pdf代表要生成pdf文件,jpg代表要生成jpg图片
     */
    public static void parseHtml2Pdf(HttpServletResponse response, String fileName, String puppeteerjs, String webSiteUrl, String types) {
        try {
            Runtime rt = Runtime.getRuntime();
            //Process p = rt.exec("node C:\\Users\\boshi\\Desktop\\iview-admin-master\\hn.js https://www.baidu.com pdf");
            Process p = rt.exec("node "+puppeteerjs+" "+webSiteUrl+" "+types);
            InputStream is = p.getInputStream();
            BufferedInputStream bf = new BufferedInputStream(is);
            byte[] data = IOUtils.toByteArray(bf);
            fileName = URLEncoder.encode(fileName, "UTF-8");
            response.setHeader("Content-Disposition", "attachment; filename=\"" + fileName + "\"");
            response.addHeader("Content-Length", "" + data.length);
            response.setContentType("application/octet-stream;charset=UTF-8");
            OutputStream outputStream = new BufferedOutputStream(response.getOutputStream());
            outputStream.write(data);
            outputStream.flush();
            outputStream.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

4. setContent.js 对应的java调用代码如下:

  public void parseHtml2Pdf(String htmlFileName) {
        try {
            Runtime rt = Runtime.getRuntime();
            Process p = rt.exec("node " + createPdfJsPath + "setContent.js " + this.getHtmlTempPath(htmlFileName));
            InputStream is = p.getInputStream();
            BufferedInputStream bf = new BufferedInputStream(is);
            byte[] data = IOUtils.toByteArray(bf);
            File file = new File(diseaseControlPdfPath + htmlFileName + ".pdf");
            IOUtils.write(data,new FileOutputStream(file));
        } catch (IOException e) {
            log.error("in parseHtml2Pdf has an error,e is ",e);
        }
    }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]中的代码是使用puppeteer.js来生成PDF文件的示例代码。它使用了puppeteer库来模拟浏览器行为,访问指定的URL,并将页面内容保存为PDF文件。代码中的`puppeteer.launch()`方法用于启动一个浏览器实例,`browser.newPage()`方法用于创建一个新的页面实例,`page.goto()`方法用于导航到指定的URL,`page.pdf()`方法用于将页面内容保存为PDF文件。根据代码中的参数,可以选择保存为PDF文件或者关闭浏览器实例。 引用\[2\]中的Java调用代码是调用了一个Node.js脚本`setContent.js`来将HTML内容换为PDF文件。它使用了`Runtime`类来执行命令行命令,通过`Process`类来获取命令行输出,并将输出保存为PDF文件。 引用\[3\]中的`setContent.js`是一个用于将HTML内容换为PDF文件的Node.js脚本。它使用了puppeteer库来模拟浏览器行为,读取指定的HTML文件内容,将内容设置到页面中,然后将页面内容保存为PDF文件。 综上所述,这些代码示例展示了如何使用puppeteer库来生成PDF文件,可以通过调用Node.js脚本或者在Java中执行命令行命令来实现。 #### 引用[.reference_title] - *1* *2* *3* [java+puppeteer实现htmlpdf文件](https://blog.csdn.net/linwei_1029/article/details/125429715)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值