当我尝试使用->get(URL)发出WWW::Mechanize::Firefox请求时,如何正确地使用超时
my $mech = WWW::Mechanize::Firefox->new(timeout => 10);似乎不起作用
发布于 2016-04-06 20:07:26
这是有可能的模拟,至少在很好的程度上。
您可以关闭get的同步,在这种情况下,调用应该立即返回。然后轮询每个$sleep_time直到超时,并对页面是否完成进行一些测试。睡眠允许完成所有其他好页面,因此可以适当地设置$sleep_time。
my $timeout = 10;
my $sleep_time = 1;
my $page = get($url, synchronize => 0);
for (1..$timeout) {
# Test some page property that will confirm that it loaded
last if $page->title eq $expected_title;
sleep $sleep_time;
}问题是如何准确地确认每一页,但这应该提供一个工作超时。
https://stackoverflow.com/questions/34662308
复制相似问题