Puppeteer Chromium Resolver

1,562 阅读1分钟

首先,谷歌把Chromium支持了Headless,也就是无头浏览器,不用界面直接在CI模式下运行,宣布了phantomjs下岗

Headless几大应用:

  • 爬虫技术
  • 前端unit test单元测试,比如结合karma+jasmine这些
  • UI automation test,web界面自动化测试 然后,谷歌还做了一个Puppeteer,也就是用来操作浏览器的一套接口,可以很方便和Chromium浏览器通讯

但是,安装Puppeteer的时候,需要从谷歌官方网站下载对应操作系统的Chromium,下载经常失败

尽管可以使用手动下载,但毕竟不能自动化,然后就是从淘宝镜像下载,也需要设置环境变量

于是做了一个Puppeteer Chromium Resolver ,用来自动解决这些问题:

  • 自动从本机搜索chromium
  • 支持从淘宝镜像下载chromium,速度快不用翻墙
  • 缓存已经下载的chromium到本地
  • 检测chromium是否可以成功启动
  • 返回Puppeteer对象和chromium的执行路径executablePath

安装

npm install puppeteer-chromium-resolver --save

使用

var puppeteerResolver = require("puppeteer-chromium-resolver");
var revisionInfo = await puppeteerResolver({
    revision: "",
    detectionPath: "",
    folderName: '.chromium-browser-snapshots',
    hosts: ["https://storage.googleapis.com", "https://npm.taobao.org/mirrors"],
    retry: 3
});

console.log("Chromium revision installed and launchable is " + revisionInfo.launchable);

var browser = await revisionInfo.puppeteer.launch({
    headless: true,
    args: ['--no-sandbox'],
    executablePath: revisionInfo.executablePath
}).catch(function (error) {
    console.log(error);
});

var page = await browser.newPage();
await page.goto('https://www.google.com');
await browser.close();