手动下载 Chrome,解决 puppeteer 无法使用问题

原文地址:https://marxjiao.com/2018/08/26/puppeteer-install/

因为网络原因,国内安装 puppeteer 的时候会报网络超时。这里使用 puppeteer-core 之后使用手动下载的 Chrome 进行操作。思路很简单,安装一个不带浏览器的 puppeteer,再使用的时候将浏览器地址指向一个可执行的 Chrome 浏览器文件。

安装

安装puppeteer-core

yarn add puppeteer-core

找到 puppeteer 中对应的浏览器并下载

node_modules/puppeteer-core/lib/BrowserFetcher.js 中找到各平台 Chrome 下载地址。其中%s 替换为 DEFAULT_DOWNLOAD_HOST 的值,%d 替换为版本号。

下载地址

node_modules/puppeteer-core/packages.json 中找到版本号

版本号

替换后得到下载地址

https://storage.googleapis.com/chromium-browser-snapshots/Mac/579032/chrome-mac.zip

下载后解压,放在项目目录中,这里我放在 chrome 下。

使用

这样就可以使用了。

使用代码

const puppeteer = require('puppeteer-core');
const path = require('path');

(async () => {
    const browser = await puppeteer.launch({
        // 这里注意路径指向可执行的浏览器。
        // 各平台路径可以在 node_modules/puppeteer-core/lib/BrowserFetcher.js 中找到
        // Mac 为 '下载文件解压路径/Chromium.app/Contents/MacOS/Chromium'
        // Linux 为 '下载文件解压路径/chrome'
        // Windows 为 '下载文件解压路径/chrome.exe'
        executablePath: path.resolve('./chrome/Chromium.app/Contents/MacOS/Chromium')
    });
    const page = await browser.newPage();
    await page.setViewport({
        width: 375,
        height: 667,
        deviceScaleFactor: 1,
        isMobile: true
    })
    await page.goto('https://marxjiao.com/');
    await page.screenshot({path: 'marx-blog.png'});
    await browser.close();
})();

执行文件

node index.js

执行后可看到,图片已经截图出来了

截图

代码地址: https://github.com/MarxJiao/puppeteer-test

推荐阅读更多精彩内容

  • 心态疗愈(AH) 是一种跨文化的自我疗愈的方法,帮助我们清除自己强加在心灵上的障碍,比如:判断、责备、羞愧、自我谴...
    位凤莲的践行之旅阅读 611评论 0 0
  • 贺联欢会 晋阳古镇聚英豪, 翰墨馨香品韵高。 各展艺精抒特色, 急敲杯韵润心潮。
    弓智阅读 147评论 3 12
  • 去年暑假,壮壮妈约我们几个小伙伴一起给孩子们报名学游泳,当时觉得轩轩喜欢玩水,应该比较感兴趣吧,于是就一起报名了。...
    xshedy阅读 287评论 0 1
  • 访得梅花花已成,匆匆已是旧桃更。 尊前守岁天涯客,灯下思乡游子情。 锁断窗前三尺雪,坐观身畔两色枰。 萦怀何必总成...
    田园读书人阅读 479评论 0 5