如果您来自未来并且无缘无故地遇到 puppeteer 问题,请尝试先降级 puppeteer 版本,看看问题是否仍然存在。
这似乎是 Chromium 开发版本 73.0.3679.0 的错误,错误日志说它无法以某种方式加载特定的脚本,但我们仍然可以手动加载脚本。
解决方案:
使用 Puppeteer 版本 1.11.0 解决了这个问题。但是,如果您想使用 puppeteer 版本 1.12.2 但使用不同的 chromium 修订版,则可以使用该executablePath
参数。
以下是 puppeteer 上使用的各个版本(在此回答点),
- Chromium 73.0.3679.0 - Puppeteer v1.12.2
- Chromium 72.0.3582.0 - Puppeteer v1.11.0
- Chromium 71.0.3563.0 - Puppeteer v1.9.0
- Chromium 70.0.3508.0 - Puppeteer v1.7.0
- Chromium 69.0.3494.0 - Puppeteer v1.6.2
我检查了本地安装的 chrome,它正在正确加载页面,
$(which google-chrome) --version
Google Chrome 72.0.3626.119
注意:puppeteer 团队在他们的文档中建议专门使用随代码提供的 chrome(很可能是最新的开发人员版本),而不是使用不同的修订版。
username
当所有网络请求完成并且输入可见时,我还稍微编辑了代码以完成加载。
const puppeteer = require("puppeteer");
(async () => {
const browser = await puppeteer.launch({
headless: false,
executablePath: "/usr/bin/google-chrome"
});
const page = await browser.newPage();
const url = "https://ccalderon-reinvent.awsapps.com/connect/ccp#/";
await page.goto(url, { waitUntil: "networkidle0" });
console.log("waiting for username input");
await page.waitForSelector("#wdc_username", { visible: true });
await page.screenshot({ path: "example.png" });
await browser.close();
})();
具体的修订号可以通过多种方式获得,一种是查看package.json
puppeteer包的。网址1.11.0
是,
https://github.com/GoogleChrome/puppeteer/blob/v1.11.0/package.json
如果您想自动下载 chrome 修订版,您可以使用它browserFetcher
来获取特定修订版。
const browserFetcher = puppeteer.createBrowserFetcher();
const revisionInfo = await browserFetcher.download('609904'); // chrome 72 is 609904
const browser = await puppeteer.launch({executablePath: revisionInfo.executablePath})
结果: