PhantomJS facebook登录表单未完全提交

PhantomJS facebook login form not fully submitted

本文关键字:提交 表单 facebook 登录 PhantomJS      更新时间:2023-09-26

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

打开页面填充字段,但不提交。我尝试控制台查看表单提交,它首先返回未定义,然后提交。

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);

你至少有两个问题

  • 由于提交表单通常会引起一些网络请求,因此结果不会立即可用,但您假设它将立即可用,因为您会立即渲染屏幕截图以查看发生了什么。该截图不会显示提交后的页面。它将在提交过程中显示一个页面。当提交结果到达浏览器时,您需要将渲染移动到下一步。

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

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();
    }
]