PhantomJS的网页超时[英] phantomJS webpage timeout

问题描述

我已经设置了一个脚本来为我们的应用创建网页截图.它运行完美,一切都很好,直到我遇到网址损坏的图像:

 "<img src='http://testserver.our.intranet/fetch/image/373e8fd2339696e2feeb680b765d626e' />"

我已经设法在 6 秒后使用下面的脚本破坏了脚本,在它永远循环之前.

但是,是否可以忽略网络请求(AKA 将图像从 DOM 中取出),然后继续创建没有图像的拇指,(或注入的图像缺少图像!)

var page = require('webpage').create(),
    system = require('system'),
    address, output, size;

if (system.args.length < 3 || system.args.length > 5) {
    phantom.exit(1);
} else {
    address = system.args[1];
    output  = system.args[2];
    page.viewportSize = { width: 640, height: 640 };
    page.zoomFactor = 0.75;
    page.clipRect = { top: 10, left: 0, width: 640, height: 490 };
    try{
        page.open(address, function (status) {
            if (status !== 'success') {
                console.log('Unable to load the address!');
                phantom.exit();
            } else {
                window.setTimeout(function () {
                    page.render(output);
                    phantom.exit();
                }, 200);
            }
        });    
    } finally{
        setTimeout(function() {
            console.log("Max execution time " + Math.round(6000) + " seconds exceeded");
            phantom.exit(1);
        }, 6000);
    }
}

推荐答案

PhantomJS 1.9 引入了一个新设置 resourceTimeout,用于控制请求在被取消之前需要多长时间.除此之外,如果/当请求超时时,会触发一个 onResourceTimeout 事件.

以下是说明上述所有内容的代码片段:

var page = require('webpage').create();  
page.settings.resourceTimeout = 5000; // 5 seconds
page.onResourceTimeout = function(e) {
  console.log(e.errorCode);   // it'll probably be 408 
  console.log(e.errorString); // it'll probably be 'Network timeout on resource'
  console.log(e.url);         // the url whose request timed out
  phantom.exit(1);
};

page.open('http://...', function (status) {
...
}

不幸的是,这些选项现在没有很好的文档记录.我必须通过 GitHub 讨论PhantomJS 源代码 以便找到它们.

本文地址:https://www.itbaoku.cn/post/1739862.html