首先,谷歌把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();