手動下載Chrome并解決puppeteer無法使用問題
因為網(wǎng)絡(luò)原因,國內(nèi)安裝 puppeteer 的時候會報網(wǎng)絡(luò)超時。這里使用 puppeteer-core 之后使用手動下載的 Chrome 進行操作。思路很簡單,安裝一個不帶瀏覽器的 puppeteer ,再使用的時候?qū)g覽器地址指向一個可執(zhí)行的 Chrome 瀏覽器文件。
安裝
安裝 puppeteer-core 。
yarn add puppeteer-core
找到 puppeteer 中對應(yīng)的瀏覽器并下載
在 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({
// 這里注意路徑指向可執(zhí)行的瀏覽器。
// 各平臺路徑可以在 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();
})();
執(zhí)行文件
node index.js
執(zhí)行后可看到,圖片已經(jīng)截圖出來了

代碼地址:https://github.com/MarxJiao/puppeteer-test
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Node.js操作Firebird數(shù)據(jù)庫教程
express.js如何做mysql注入與node-mysql中防止SQL注入方法解析

