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


Posted in Javascript onNovember 12, 2018

因为网络原因,国内安装 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 替换为版本号。

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

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

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

替换后得到下载地址

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

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

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE6 弹出Iframe层中的文本框“经常”无法获得输入焦点
Dec 27 Javascript
jquery $(document).ready() 与window.onload的区别
Dec 28 Javascript
jquery下onpropertychange事件的绑定方法
Aug 01 Javascript
javascript函数作用域学习示例(js作用域)
Jan 13 Javascript
Jquery遍历节点的方法小集
Jan 22 Javascript
jQuery中Nicescroll滚动条插件的用法
Nov 10 Javascript
js通过指定下标或指定元素进行删除数组的实例
Jan 12 Javascript
js+html5实现手机九宫格密码解锁功能
Jul 30 Javascript
Egg.js 中 AJax 上传文件获取参数的方法
Oct 10 Javascript
element实现合并单元格通用方法
Nov 13 Javascript
Vue学习之常用指令实例详解
Jan 06 Javascript
ReactRouter的实现方法
Jan 25 Javascript
vue elementui form表单验证的实现
Nov 11 #Javascript
跨域请求两种方法 jsonp和cors的实现
Nov 11 #Javascript
浅谈webpack+react多页面开发终极架构
Nov 11 #Javascript
Vue项目引进ElementUI组件的方法
Nov 11 #Javascript
webpack中如何使用雪碧图的示例代码
Nov 11 #Javascript
vue组件从开发到发布的实现步骤
Nov 11 #Javascript
详解如何在Node.js的httpServer中接收前端发送的arraybuffer数据
Nov 11 #Javascript
You might like
在openSUSE42.1下编译安装PHP7 的方法
2015/12/24 PHP
php原生导出excel文件的两种方法(推荐)
2016/11/19 PHP
php实时倒计时功能实现方法详解
2017/02/27 PHP
PHP更安全的密码加密机制Bcrypt详解
2017/06/18 PHP
[原创]PHP实现SQL语句格式化功能的方法
2017/07/28 PHP
Laravel 5.5 异常处理 & 错误日志的解决
2019/10/17 PHP
javascript RadioButtonList获取选中值
2009/04/09 Javascript
JavaScript栏目列表隐藏/显示简单实现
2013/04/03 Javascript
详解JavaScript中undefined与null的区别
2014/03/29 Javascript
纯javascript实现简单下拉刷新功能
2015/03/13 Javascript
jQuery oLoader实现的加载图片和页面效果
2015/03/14 Javascript
JavaScript Date 知识浅析
2017/01/29 Javascript
浅谈$_FILES数组为空的原因
2017/02/16 Javascript
bootstrap fileinput 上传插件的基础使用
2017/02/17 Javascript
bootstrap警告框示例代码分享
2017/05/17 Javascript
Angular指令之restict匹配模式的详解
2017/07/27 Javascript
基于vue-ssr的静态网站生成器VuePress 初体验
2018/04/17 Javascript
解决angularJS中input标签的ng-change事件无效问题
2018/09/13 Javascript
微信小程序页面间值传递的两种方法
2018/11/26 Javascript
Element实现表格分页数据选择+全选所有完善批量操作
2019/06/07 Javascript
layui table去掉右侧滑动条的实现方法
2019/09/05 Javascript
Vue开发环境跨域访问问题
2020/01/22 Javascript
Javascript执行流程细节原理解析
2020/05/14 Javascript
Python内置函数bin() oct()等实现进制转换
2012/12/30 Python
python psutil库安装教程
2018/03/19 Python
在自动化中用python实现键盘操作的方法详解
2019/07/19 Python
python 哈希表实现简单python字典代码实例
2019/09/27 Python
Python文件路径名的操作方法
2019/10/30 Python
CSS3 伪类选择器 nth-child()说明
2010/07/10 HTML / CSS
护理学专业推荐信
2013/12/03 职场文书
幼儿园教师请假制度
2014/01/16 职场文书
企业仓管员岗位职责
2014/06/15 职场文书
2014年党的群众路线活动个人整改措施
2014/10/28 职场文书
管理人员岗位职责
2015/02/14 职场文书
信息简报范文
2015/07/21 职场文书
使用qt quick-ListView仿微信好友列表和聊天列表的示例代码
2021/06/13 Python