Pupeteer脚本冻结

时间:2019-02-01 19:27:40

标签: javascript puppeteer

我正在编写一个脚本来查看注册服务商中的域。我设法使其正常运行,但是由于某种原因,脚本会在随机时间(搜索2、4、10个域后)停止,因此我不知道为什么或如何调试它。 我正在使用Puppeteer,但是我对此很陌生,所以也许我在犯一些基本错误。

到目前为止,脚本如下:

const puppeteer = require('puppeteer');
const DOMS = require('./dominios');

//Traemos los selectores de nic.ar

const SELECTOR_BUSQUEDA = '#edit-txtbuscar';
const SELECTOR_BOTON = '#btn-consultar-block-submit';
const SELECTOR_DNS = '#body > div.dialog-off-canvas-main-canvas > div.main-container.container.js-quickedit-main-content > div > section > div > div > div:nth-child(6) > table.tablaRespon3 > tbody > tr:nth-child(1) > td:nth-child(1)';

//Generamos las variables de busqueda

//Funcion principal

async function run() {
  const browser = await puppeteer.launch({
    args: ['--no-sandbox', '--disable-setuid-sandbox', 'headless:false']
  });
  let array_doms = [];
  let respuesta = "";
  array_doms = DOMS.Dominios;
  let bodyHandle;
  let resultado;
  const page = await browser.newPage();
  for (let i = 0; i < array_doms.length; i++) {
    await page.goto('https://nic.ar');
    await page.click(SELECTOR_BUSQUEDA);
    await page.keyboard.type(array_doms[i]);
    await page.click(SELECTOR_BOTON);
    await page.waitForNavigation();
    //Trae el selector de la tabla de resultados de la busqueda
    bodyHandle = await page.$('body > div.dialog-off-canvas-main-canvas > div.main-container.container.js-quickedit-main-content > div > section > div > div > div:nth-child(6) > table.tablaRespon3 > tbody > tr:nth-child(1) > td:nth-child(1)');
    resultado = await page.evaluate(body => body.innerHTML, bodyHandle);
    await bodyHandle.dispose();
    respuesta = "El dominio " + array_doms[i] + " apunta a " + resultado;
    console.log(respuesta);
  }
};

run();
~

我知道代码看起来很讨厌,但我仍在学习。

1 个答案:

答案 0 :(得分:3)

这两行可能存在竞争状况:

await page.click(SELECTOR_BOTON);
await page.waitForNavigation();

有时导航发生在页面单击解析之前,有时在此之后。为了避免这种效果,请尝试将这些行替换为以下行:

await Promise.all([
  page.click(SELECTOR_BOTON),
  page.waitForNavigation(),
]);