Je tente d'écrire un script PhantomJS qui automatisera la soumission d'applications Android sur l'Amazon App Store. Je base mon script sur cet exemple : http://code-epicenter.com/how-to-login-amazon-using-phantomjs-working-example/. J'ai modifié cet exemple pour fonctionner avec https://developer.amazon.com/home.html au lieu de l'URL utilisée dans l'exemple.
Voici ce que j'ai essayé:
var steps=[];
var testindex = 0;
var loadInProgress = false;//This is set to true when a page is still loading
/*********SETTINGS*********************/
var username = 'inconnu';
var password = 'inconnu';
var webPage = require('webpage');
var page = webPage.create();
page.settings.userAgent = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.157 Safari/537.36';
page.settings.javascriptEnabled = true;
page.settings.loadImages = false;//Script is much faster with this field set to false
phantom.cookiesEnabled = true;
phantom.javascriptEnabled = true;
/*********SETTINGS END*****************/
/* Get command line args user password*/
var system = require('system');
var args = system.args;
if (args.length === 1) {
console.log('Try to pass some arguments when invoking this script!');
} else {
args.forEach(function(arg, i) {
console.log(i + ': ' + arg);
if ( i === 1 ) { username = arg; }
if ( i === 2 ) { password = arg; }
});
}
if ( username == 'inconnu' ) {
console.log('Veuillez spécifier le nom d\'utilisateur et le mot de passe');
phantom.exit();
}
if ( password == 'inconnu' ) {
console.log('Veuillez spécifier le nom d\'utilisateur et le mot de passe');
phantom.exit();
}
console.log('Tous les réglages sont chargés, commençons l'exécution');
page.onConsoleMessage = function(msg) {
console.log(msg);
};
/**********DÉFINIR LES ÉTAPES QUE FANTOM DOIT EFFECTUER***********************/
steps = [
/*
* Étape 1 - Ouvrir la page d'accueil d'Amazon
*/
function(){
console.log('Étape 1 - Ouvrir la page d\'accueil d\'Amazon');
page.open("https://developer.amazon.com/home.html", function(status) {
console.log('Le statut est '+ status );
});
},
/*
* Étape 2 - Remplir et soumettre le formulaire de connexion
*/
function(username,password){
console.log('Étape 2 - Remplir et soumettre le formulaire de connexion');
// var appActionToken = page.evaluate(function() { return $('input[name="appActionToken"]').attr('value'); });
// console.log( 'appActionToken is ' + appActionToken );
console.log( 'nom d\'utilisateur est ' + username );
page.evaluate(function(username,password){
console.log( ' nom d\'utilisateur est ' + username );
document.getElementById("ap_email").value=username;
document.getElementById("ap_password").value=password;
document.getElementById("ap_signin_form").submit();
},username, password);
},
/*
* Étape 3 - Attendre qu'Amazon connecte l'utilisateur. Après la connexion réussie de l'utilisateur,
* l'utilisateur est redirigé vers la page d'accueil. Le contenu de la page d'accueil est enregistré dans AmazonLoggedIn.html.
* Vous pouvez trouver ce fichier où se trouve le fichier phantomjs.exe. Vous pouvez ouvrir ce fichier avec Chrome pour vous assurer que vous êtes connecté.
*/
function(){
console.log("Étape 3 - blah blah blah");
var fs = require('fs');
var result = page.evaluate(function() {
return document.querySelectorAll("html")[0].outerHTML;
});
fs.write('AmazonLoggedIn.html',result,'w');
},
];
/**********FIN DES ÉTAPES QUE FANTOM DOIT EFFECTUER***********************/
//Exécuter les étapes une par une
interval = setInterval(executeRequestsStepByStep,50);
function executeRequestsStepByStep(){
if (loadInProgress == false && typeof steps[testindex] == "function") {
console.log("testindex est " + testindex );
if ( testindex == 1 ) {
console.log( "nom d'utilisateur est " + username );
steps[testindex](username, password);
} else {
steps[testindex]();
}
testindex++;
}
if (typeof steps[testindex] != "function") {
console.log("test complet !");
phantom.exit();
}
}
/**
* Ces auditeurs sont très importants pour que Phantom fonctionne correctement.
* En utilisant ces auditeurs, nous contrôlons le marqueur loadInProgress qui contrôle si une page est entièrement chargée.
* Sans cela, nous obtiendrons le contenu de la page, même si une page n'est pas encore entièrement chargée.
*/
page.onLoadStarted = function() {
loadInProgress = true;
console.log('Chargement démarré');
};
page.onLoadFinished = function() {
loadInProgress = false;
console.log('Chargement terminé');
};
page.onConsoleMessage = function(msg) {
console.log(msg);
};
Lorsque j'exécute le script, la sortie est écrite dans le fichier AmazonLoggedIn.html mais le contenu indique que la connexion a échoué. Je suis assez sûr d'utiliser les identifiants corrects. Voici à quoi ressemble le AmazonLoggedIn.html résultant: