Тайм-аут веб-страницы phantomJS
Я создал script для создания веб-снимков нашего приложения.
Он работает отлично, и все в порядке. Пока я не сталкиваюсь с изображением со сломанным адресом:
"<img src='http://testserver.our.intranet/fetch/image/373e8fd2339696e2feeb680b765d626e' />"
Мне удалось сломать script через 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);
}
}
Ответы
Ответ 1
В 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, чтобы узнать их.