puppeteer 安装时跳过 chrome 安装的方法

18,580次阅读
4 条评论

共计 2020 个字符,预计需要花费 6 分钟才能阅读完成。

提醒:本文最后更新于2025-07-07 14:51,文中所关联的信息可能已发生改变,请知悉!

puppeteer 安装时跳过 chrome 安装的方法

puppeteer 安装时跳过下载 chrome

在项目目录里安装 puppeteer 时,都会下载 Chromium。这个慢不说,也会造成重复下载、耗时过长等问题。那么可以这么来做跳过 Chromium 的下载:

npm install puppeteer --ignore-scripts

然后在脚本中通过配置项 executablePath,指定 Chromium 所在的位置(也可以指定为本地 Chrome 浏览器安装的地址)。示例:

const puppeteer = require('puppeteer');
puppeteer.launch({
headless: false,
// executablePath: 'C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe',
executablePath: 'C:\\Program Files\\nodejs\\node_modules\\puppeteer\\.local-chromium\\win64-508693\\chrome-win32\\chrome.exe'
}).then(async browser => {
const page = await browser.newPage();
await page.goto('https://lzw.me');
await page.screenshot({path: 'lzwme.png'});
browser.close();
}).catch(err => {
console.log(err);
});

提示:

当前淘宝仓库已经有该镜像,可以通过设置环境变量方式从该镜像地址进行下载安装。命令示例:

# window
set PUPPETEER_DOWNLOAD_HOST=https://npm.taobao.org/mirrors
npm install puppeteer

手动下载 chrome

有的同学可能会问,在墙里下载不到开发版的 chrome 怎么办。翻看仓库源码可以得知,下载地址是这样的:

const downloadURLs = {
linux: 'https://storage.googleapis.com/chromium-browser-snapshots/Linux_x64/%d/chrome-linux.zip',
mac: 'https://storage.googleapis.com/chromium-browser-snapshots/Mac/%d/chrome-mac.zip',
win32: 'https://storage.googleapis.com/chromium-browser-snapshots/Win/%d/chrome-win32.zip',
win64: 'https://storage.googleapis.com/chromium-browser-snapshots/Win_x64/%d/chrome-win32.zip',
};

选择对应的平台,将 %d 替换成具体的编号,然后使用迅雷这种 P2P 下载即可。这个编号可以从 puppeteer/package.json 中的 puppeteer.chromium_revision 字段获得。

另外,你也可以从淘宝镜像仓库进行下载,地址如下:

https://npm.taobao.org/mirrors/chromium-browser-snapshots/

相关参考:

https://github.com/GoogleChrome/puppeteer/issues/244
https://github.com/GoogleChrome/puppeteer/issues/288

关于 puppeteer

在以前,当需要进行无界面的浏览器自动访问网站执行动作时,大都会选择 phantomjs 或 SlimerJS。

https://lzw.me/a/slimerjs-phantomjs-casperjs.html 这篇文章中我们对 phantomjs 进行了简单的使用介绍。

puppeteer 则是 chrome 官方团队出品的同类工具。当 puppeteer 出来后,phantomjs 即宣布不再继续开发维护。puppeteer 的使用很简单,功能更丰富,可以通过脚本实现各种自动化功能需求。

本文不对 puppeteer 具体使用作详细介绍。关于 puppeteer 的使用示例可参考这几篇文章:

https://github.com/laispace/puppeteer-explore
https://github.com/zhentaoo/puppeteer-deep
https://cloud.tencent.com/community/article/529168
https://github.com/GoogleChrome/puppeteer

正文完
 0
任侠
版权声明:本站原创文章,由 任侠 于2017-10-31发表,共计2020字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(4 条评论)
验证码
valleykid 评论达人 LV.1
2018-02-07 17:57:54 回复
Google Chrome 64.0.3282.140 Google Chrome 64.0.3282.140 Mac OS X 10.12.6 Mac OS X 10.12.6

安装puppeteer时如果无法下载Chromium,可以使用puppeteer-cn代替的。这个包先检查你本地chrome是否大于59,再决定是否安装Chromium,并且使用国内源安装,速度很快且保证成功。

 Macintosh  Chrome  美国弗吉尼亚阿里云
    Moose 评论达人 LV.1
    2018-02-09 10:21:37 回复
    Google Chrome 63.0.3239.132 Google Chrome 63.0.3239.132 Mac OS X 10.13.1 Mac OS X 10.13.1

    @valleykid 请问我在mac下 executablePath:’/Applications/Google Chrome.app/Contents/MacOS/Google\ Chrome’ 设置成这样。
    结果报错 UnhandledPromiseRejectionWarning: Error: Failed to launch chrome! spawn /Applications/Google Chrome.app/Contents/MacOS/Google\ Chrome ENOENT
    是这个路径的问题么?

     Macintosh  Chrome  中国北京北京市联通
      2018-02-12 09:05:29 回复
      Google Chrome 63.0.3239.132 Google Chrome 63.0.3239.132 Windows 10 x64 Edition Windows 10 x64 Edition

      @Moose 是的,ENOENT一般是没找到文件或路径
      你的路径应该是有问题的

       Windows  Chrome  中国广东省广州市电信
米扑博客 评论达人 LV.1
2017-11-08 23:16:39 回复
Google Chrome 61.0.3163.100 Google Chrome 61.0.3163.100 Mac OS X 10.12.6 Mac OS X 10.12.6

好文章,需要懂得欣赏的人,博主辛苦了 :cool:

 Macintosh  Chrome  中国北京北京市电信