我有两个连续运行的page.open调用。在请求资源时,我将给定资源的url输出到控制台。
var page = require('webpage').create();
var resourceCounter = 0;
page.onResourceRequested = function (resource) {
console.log(resourceCounter++ + '.\t', resource.url);
};
page.open('http://phantomjs.org');
setTimeout(function () {
resourceCounter = 0;
page.open('http://phantomjs.org/documentation');
}, 5000);
setTimeout(function(){
phantom.exit();
}, 10000);
如果我尝试在不同的域上打开两个URL,一切都按预期工作 - 我看到了页面所请求资源的完整列表。但是,如果我请求同一个页面两次,或者同一个域中的两个页面(如上例所示),而不是看到两次列出的页面请求的资源,我会看到:
Resource requests for: http://phantomjs.org/
0 http://phantomjs.org/
1 http://phantomjs.org/
2 http://phantomjs.org/
3 http://fonts.googleapis.com/css?family=Droid+Sans:400,700
4 http://phantomjs.org/css/main.css
5 http://www.google-analytics.com/ga.js
6 https://s3.amazonaws.com/github/ribbons/forkme_left_white_ffffff.png
7 http://phantomjs.org/img/phantomjs-logo.png
8 http://phantomjs.org/img/icon-release.png
9 http://phantomjs.org/img/icon-ml.png
10 http://phantomjs.org/img/icon-bugs.png
11 http://www.google-analytics.com/__utm.gif?utmwv=5.5.0&utms=1&utmn=1675561797&utmhn=phantomjs.org&utmcs=UTF-8&utmsr=2560x1440&utmvp=400x300&utmsc=32-bit&utmul=en-us&utmje=0&utmfl=-&utmdt=PhantomJS%20%7C%20PhantomJS&utmhid=1661770756&utmr=-&utmp=%2F&utmht=1398973179893&utmac=UA-21665893-1&utmcc=__utma%3D205055825.123505717.1398973180.1398973180.1398973180.1%3B%2B__utmz%3D205055825.1398973180.1.1.utmcsr%3D(direct)%7Cutmccn%3D(direct)%7Cutmcmd%3D(none)%3B&utmu=q~
Resource requests for: http://phantomjs.org/documentation/
0 http://phantomjs.org/documentation/
1 http://www.google-analytics.com/__utm.gif?utmwv=5.5.0&utms=2&utmn=1424746795&utmhn=phantomjs.org&utmcs=UTF-8&utmsr=2560x1440&utmvp=400x300&utmsc=32-bit&utmul=en-us&utmje=0&utmfl=-&utmdt=Documentation%20%7C%20PhantomJS&utmhid=873610113&utmr=-&utmp=%2Fdocumentation%2F&utmht=1398973180268&utmac=UA-21665893-1&utmcc=__utma%3D205055825.123505717.1398973180.1398973180.1398973180.1%3B%2B__utmz%3D205055825.1398973180.1.1.utmcsr%3D(direct)%7Cutmccn%3D(direct)%7Cutmcmd%3D(none)%3B&utmu=q~
换句话说,通过page.onResourceRequested
为第二个page.open()调用捕获的结果将被截断。
注意:我看到禁用缓存的这种行为。
非常感谢任何帮助!