PhantomJS 的最新版本允许我们使用--web-security=no标志来表示不尊重安全策略。
下一个脚本(仅 PhantomJS)获取 iframe 中链接的标题,即 iframe (adsense)。
/*
Accessing an iframe (different domain) with PhantomJS
Example by deerme.org
*/
var page = require('webpage').create(), system = require('system'), t, address;
if (system.args.length === 1)
{
console.log('Usage: phantomfs iframe.js <some URL>');
phantom.exit();
}
t = Date.now();
address = system.args[1];
page.open(address, function (status)
{
if (status !== 'success')
{
console.log('FAIL to load the address');
}
else
{
t = (Date.now()) - t;
title = page.evaluate( function(){
return document.title;
});
linkTitle = page.evaluate( function(){
// The site containing jQuery?
if ( typeof(jQuery) == "undefined" )
{
// Force Load
page.injectJs('http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js');
}
// first iframe #aswift_2
// second iframe #google_ads_frame3
return jQuery("#aswift_2").contents()
.find("body")
.find("#google_ads_frame3")
.contents()
.find("body")
.contents()
.find("a:last")
.attr("title");
});
console.log('Loading time: ' + t + ' msec');
console.log('Webpage title: ' + title);
console.log('Link title (iframe adsense): ' + linkTitle);
}
phantom.exit();
});
请记住,使用参数运行
phantomjs --web-security=no iframe.js http://anysite.org