PhantomJS facebook登录表格未完全提交

时间:2015-09-16 20:32:57

标签: javascript facebook web-scraping phantomjs form-submit

我正试图通过phantomJS登录facebook,它运行正常,但是当我运行它时不提交表单。

它会打开页面填充字段但不提交。我试过控制台看表单提交它返回undefined然后提交。

var page = require('webpage').create();
var system = require('system');
var stepIndex = 0;
var loadInProgress = false;

email = system.args[1];
password = system.args[2];

page.onLoadStarted = function() {
    loadInProgress = true;
    console.log("load started");
};

page.onLoadFinished = function() {
    loadInProgress = false;
    console.log("load finished");
};

var steps = [
    function() {
        page.open("http://www.facebook.com/login.php", function(status) {
            page.evaluate(function(email, password) {
                document.querySelector("input[name='email']").value = email;
                document.querySelector("input[name='pass']").value = password;

                document.querySelector("#login_form").submit();

                console.log("Login submitted!");
            }, email, password);
            page.render('output.png');
        });
    },
    function() {
        console.log(document.documentElement.innerHTML);
    },
    function() {
        phantom.exit();
    }
]

setInterval(function() {
    if (!loadInProgress && typeof steps[stepIndex] == "function") {
        console.log("step " + (stepIndex + 1));
        steps[stepIndex]();
        stepIndex++;
    }
    if (typeof steps[stepIndex] != "function") {
        console.log("test complete!");
        phantom.exit();
    }
}, 10000);

1 个答案:

答案 0 :(得分:1)

你至少有两个问题。

  • 由于提交表单通常会产生一些网络请求,因此结果不会立即生效,但您认为它会立即可用,因为您需要立即呈现截图,看看发生了什么。该截图在提交后不会显示该页面。它会在提交期间显示一个页面。当提交结果到达浏览器时,您需要将渲染移动到下一步。

  • document在页面上下文之外没有任何意义。然而,PhantomJS将提供这样的虚拟对象。您只能访问document内的DOM(windowpage.evaluate())。

尝试

var steps = [
    function() {
        page.open("http://www.facebook.com/login.php", function(status) {
            page.evaluate(function(email, password) {
                document.querySelector("input[name='email']").value = email;
                document.querySelector("input[name='pass']").value = password;

                document.querySelector("#login_form").submit();

                console.log("Login submitted!");
            }, email, password);
        });
    },
    function() {
        page.render('output.png');
        console.log("innerHTML: " + page.evaluate(function(){
            return document.documentElement.innerHTML;
        }));
        console.log("full page: " + page.content);
    },
    function() {
        phantom.exit();
    }
]