如何在SpookyJS中使用HTTP基本身份验证

时间:2015-06-17 17:00:04

标签: javascript node.js casperjs basic-authentication spookyjs

我写了一些代码,用CasperJS进入我的Wordpress页面,带有 htaccess保护。该脚本应该登录然后更新插件。这时我可以登录并创建应该更新的插件的截图。 (也是CasperJS工作正常)

现在我希望此代码段在服务器上运行。所以我用

表达,幽灵,节点

我找到了this spooky代码段并尝试将CasperJS代码插入其中。但现在我无法用SpookyJS克服htaccess保护。有什么想法吗?

下面的代码也应该在具有怪异的nodejs服务器上运行。

var casper = require('casper').create({
    verbose: true,
    logLevel: 'debug',
    userAgent: 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.172 Safari/537.22',
    pageSettings: {
        loadImages:  false,         
        loadPlugins: false        
    },
    viewportSize: {
        width: 1900,
        height: 1200
    }

});
var x = require('casper').selectXPath;
var user_email = '<login-name>';
var user_pass = '<login-password';
var selector = '.update-link';

casper.start();

casper.setHttpAuth('<username>', '<password>');

casper.thenOpen('<wordpress url with htaccess', function() {

});

// wordpress login
casper.then(function() {
    this.page.evaluate(function(a,b) {
        document.querySelector("input[name='log']").value = a
        document.querySelector("input[name='pwd']").value = b;
        document.querySelector("#wp-submit").submit(); //nothing happened
    }, user_email, user_pass);
}).then(function(){

});

casper.thenClick(x('//*[@id="wp-submit"]'), function () {
    console.log("clicked login")
});

// An example to mark all plugins to update
casper.thenOpen('<wordpress site>/wp-admin/plugins.php', function() {
    this.waitForSelector(selector, function then() {
        this.evaluate(function (sel) {
            var x =document.querySelectorAll(sel);

            for (i = 0; i < x.length; i++) {
                x[i].style.backgroundColor = "red";
            }
        }, selector);
    });
});



casper.then(function () {
    casper.capture('update_me.png');
})

casper.run();

1 个答案:

答案 0 :(得分:0)

SpookyJS似乎没有提供与CasperJS'setHttpAuth()相同的功能,但您仍然可以通过pageSettings属性在创建过程中传递用户名和密码:

var spooky = new Spooky({
    child: {
        transport: 'http'
    },
    casper: {
        logLevel: 'debug',
        verbose: true,
        pageSettings: {
            userName: 'some username',
            password: 'some password'
        }
    }
}, function (err) {
    // your script here
});