node.js - Puppeteer 无法截图

标签 node.js puppeteer

我正在尝试使用 puppeteer 进行屏幕截图。

我遇到了很多未处理的 promise 拒绝错误的麻烦。 我浏览了许多论坛和主题,它们提出了许多不同的建议,我也应用了这些建议。

这些建议范围从使用异步函数到使用 try-catch block 。

经过改进,这是我的代码的最终版本:

const puppeteer = require('puppeteer');

async function getPic() {
    const browser = await puppeteer.launch(/*{headless: false}*/);
    const page = await browser.newPage();
    page.setViewport({width: 1000, height: 500});

    process.on("unhandledRejection", (reason, p) => {
        console.error("Unhandled Rejection at: Promise", p, "reason:", reason);
        browser.close();
    });

    try{
        await page.goto('https://www.google.com');
    }
    catch (error) {
        console.log(error);
        browser.close();
    }

    await page.screenshot({path: 'pic.png'});
    await broswer.close();
}

getPic();

尽管如此,它仍然不起作用,我收到此错误消息:

Error: Navigation Timeout Exceeded: 30000ms exceeded
    at Promise.then (C:\...\pupet test\node_modules\pupp
eteer\lib\NavigatorWatcher.js:71:21)
    at <anonymous>
Unhandled Rejection at: Promise Promise {
  <rejected> { Error: Protocol error (Target.sendMessageToTarget): Target closed
.
    at Promise (C:\...\pupet test\node_modules\puppeteer
\lib\Connection.js:198:56)
    at new Promise (<anonymous>)
    at CDPSession.send (C:\...\pupet test\node_modules\p
uppeteer\lib\Connection.js:197:12)
    at Page._screenshotTask (C:\...\pupet test\node_modu
les\puppeteer\lib\Page.js:707:24)
    at <anonymous>
  message: 'Protocol error (Target.sendMessageToTarget): Target closed.' } } rea
son: { Error: Protocol error (Target.sendMessageToTarget): Target closed.
    at Promise (C:\...\pupet test\node_modules\puppeteer
\lib\Connection.js:198:56)
    at new Promise (<anonymous>)
    at CDPSession.send (C:\...\pupet test\node_modules\p
uppeteer\lib\Connection.js:197:12)
    at Page._screenshotTask (C:\...\pupet test\node_modu
les\puppeteer\lib\Page.js:707:24)
    at <anonymous>
  message: 'Protocol error (Target.sendMessageToTarget): Target closed.' }

最佳答案

正确使用异步等待

您需要正确使用 async-await。您正在以同步方式调用异步函数。

这是经过适当等待的修改后的代码。阅读下面的代码,看看出了什么问题。

const puppeteer = require('puppeteer');
async function getPic() {
    try{ // <-- wrap the whole block in try catch
      const browser = await puppeteer.launch(/*{headless: false}*/);
      const page = await browser.newPage();
      await page.setViewport({width: 1000, height: 500}); // <-- add await here so it sets viewport after it creates the page
      await page.goto('https://www.google.com');
      await page.screenshot({path: 'pic.png'});
      await broswer.close(); // <-- close browser after everything is done
    } catch (error) {
      console.log(error);
    }
}

getPic();

检查代理设置

错误表明超时,这意味着它甚至无法加载网站。尝试检查页面是否在浏览器上正确加载。

关于node.js - Puppeteer 无法截图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49921817/

相关文章:

javascript - Node crypto.randomBytes 从函数返回 token

javascript - 在类方法中使用 Puppeteer

json - 将多个 cookie 传递给 puppeteer

javascript - 努力使用 .querySelector 查询具有相同类名的特定元素

node.js - 找不到 'node' 的类型定义文件

node.js - 错误 : Procfile does not exist, 和启动 Web 进程时出现问题

Node.js/Express 将所有内容重定向到 Angular 2 页面

javascript - 如何与 sinon 和 chai 断言 catch promise

javascript - 如何单击 puppeteer 中的一系列链接?

javascript - 在 puppeteer 中使用 xpath 选择下拉列表