PhantomJS - Méthodes

PhantomJS est une plate-forme pour aider à exécuter JavaScript sans navigateur. Pour ce faire, les méthodes suivantes sont utilisées, qui aident à ajouter le cookie, à supprimer, à effacer, à quitter le script, à injecter JS, etc.

Nous discuterons plus en détail de ces méthodes PhantomJS et de leur syntaxe dans ce chapitre. Méthodes similaires ieaddcookie, injectjs existe sur le module de la page Web, qui sera discuté dans les chapitres suivants.

PhantomJS expose les méthodes suivantes qui peuvent nous aider à exécuter JavaScript sans le navigateur -

  • addCookie
  • clearCookie
  • deleteCookie
  • Exit
  • InjectJS

Comprenons maintenant ces méthodes en détail avec des exemples.

addCookie

La méthode addcookie est utilisée pour ajouter des cookies et stocker dans les données. C'est similaire à la façon dont le navigateur le stocke. Il prend un seul argument qui est un objet avec toutes les propriétés des cookies et la syntaxe car il ressemble à celui ci-dessous -

Syntaxe

Sa syntaxe est la suivante -

phantom.addCookie ({ 
   "name" : "cookie_name",  
   "value" : "cookie_value", 
   "domain" : "localhost" 
});

Le nom, la valeur, le domaine sont des propriétés obligatoires à ajouter à la fonction addcookie. Si l'une de ces propriétés est manquante dans les objets cookie, cette méthode échouera.

  • name - spécifie le nom du cookie.

  • value - spécifie la valeur du cookie à utiliser.

  • domain - domaine auquel le cookie sera appliqué.

Exemple

Voici un exemple de addcookie méthode.

var page = require('webpage').create(),url = 'http://localhost/tasks/a.html'; 
page.open(url, function(status) { 
   if (status === 'success') {     
      phantom.addCookie({   //add name cookie1 with value = 1 
         name: 'cookie1', 
         value: '1', 
         domain: 'localhost' 
      }); 
      phantom.addCookie({   // add cookie2 with value 2 
         name: 'cookie2', 
         value: '2', 
         domain: 'localhost' 
      }); 
      phantom.addCookie({   // add cookie3 with value 3 
         name: 'cookie3', 
         value: '3', 
         domain: 'localhost' 
      }); 
      console.log('Added 3 cookies'); 
      console.log('Total cookies :'+phantom.cookies.length);  
      
      // will output the total cookies added to the url.    
   } else { 
      console.error('Cannot open file'); 
      phantom.exit(1); 
   } 
});

Exemple

a.html

<html>
   <head>
      <title>Welcome to phantomjs test page</title>
   </head>
   
   <body>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
   </body>
</html>

Le programme ci-dessus génère les éléments suivants output.

Added 3 cookies 
Total cookies :3

Les commentaires de code sont explicites.

effacer les cookies

Cette méthode permet de supprimer tous les cookies.

Syntaxe

Sa syntaxe est la suivante -

phantom.clearCookies();

Ce concept fonctionne de manière similaire à la suppression des cookies du navigateur en sélectionnant dans le menu du navigateur.

Exemple

Voici un exemple de clearCookies méthode.

var page = require('webpage').create(),url = 'http://localhost/tasks/a.html'; 
page.open(url, function(status) { 
   if (status === 'success') {     
      phantom.addCookie({   //add name cookie1 with value = 1 
         name: 'cookie1', 
         value: '1', 
         domain: 'localhost' 
      }); 
      phantom.addCookie({   // add cookie2 with value 2 
         name: 'cookie2', 
         value: '2', 
         domain: 'localhost' 
      }); 
      phantom.addCookie({   // add cookie3 with value 3 
         name: 'cookie3', 
         value: '3', 
         domain: 'localhost' 
      }); 
      console.log('Added 3 cookies'); 
      console.log('Total cookies :'+phantom.cookies.length); 
      phantom.clearCookies(); 
      console.log(
         'After clearcookies method total cookies :' +phantom.cookies.length); 
      
      phantom.exit();     
   } else { 
      console.error('Cannot open file'); 
      phantom.exit(1); 
   } 
});

a.html

<html>
   <head>
      <title>Welcome to phantomjs test page</title>
   </head>
   
   <body>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
      <h1>This is a test page</h1>
   </body>
</html>

Le programme ci-dessus génère les éléments suivants output.

Added 3 cookies 
Total cookies :3 
After clearcookies method total cookies :0

deleteCookie

Supprimez tout cookie dans le CookieJaravec une propriété 'name' correspondant à cookieName. Il reviendratrue, si supprimé avec succès; autrementfalse.

Syntaxe

Sa syntaxe est la suivante -

phantom.deleteCookie(cookiename);

Laissez-nous comprendre addcookie, clearcookies et deletecookie à l'aide d'un exemple.

Exemple

Voici un exemple pour illustrer l'utilisation de la méthode deleteCookie -

File: cookie.js

var page = require('webpage').create(),url = 'http://localhost/tasks/a.html'; 
page.open(url, function(status) { 
   if (status === 'success') {     
      phantom.addCookie({   //add name cookie1 with value = 1 
         name: 'cookie1', 
         value: '1', 
         domain: 'localhost' 
      }); 
      phantom.addCookie({   // add cookie2 with value 2 
         name: 'cookie2', 
         value: '2', 
         domain: 'localhost' 
      });
      phantom.addCookie({   // add cookie3 with value 3 
         name: 'cookie3', 
         value: '3', 
         domain: 'localhost' 
      });  
      console.log('Added 3 cookies'); 
      console.log('Total cookies :'+phantom.cookies.length); 
      
      //will output the total cookies added to the url.    
      console.log("Deleting cookie2"); 
      phantom.deleteCookie('cookie2'); 
      
      console.log('Total cookies :'+phantom.cookies.length); 
      phantom.clearCookies();
      
      console.log(
         'After clearcookies method total cookies :' +phantom.cookies.length); 
      phantom.exit(); 
   } else { 
      console.error('Cannot open file'); 
      phantom.exit(1); 
   } 
});

Le programme ci-dessus génère les éléments suivants output.

phantomjs cookie.js
Added 3 cookies
Total cookies :3
Deleting cookie2
Total cookies :2
After clearcookies method total cookies :0

Sortie

La méthode phantom.exit quittera le script qu'elle avait démarré. Il quitte le programme avec la valeur de retour mentionnée. Il donne‘0’, si aucune valeur n'est passée.

Syntaxe

Sa syntaxe est la suivante -

phantom.exit(value);

Au cas où vous n'ajoutez pas phantom.exit, la ligne de commande suppose que l'exécution est toujours en cours et ne se terminera pas.

Exemple

Prenons un exemple pour comprendre l'utilisation du exit méthode.

console.log('Welcome to phantomJs');  // outputs Welcome to phantomJS 
var a = 1; 
if (a === 1) { 
   console.log('Exit 1'); //outputs Exit 1 
   phantom.exit(); // Code exits. 
} else { 
   console.log('Exit 2'); 
   phantom.exit(1); 
}

Le programme ci-dessus génère les éléments suivants output.

phantomjs exit.js

Welcome to phantomJs 
Exit 1

Tout morceau de code après phantom.exit ne sera pas exécuté, car phantom.exit est une méthode pour terminer le script.

injectJs

InjectJs est utilisé pour ajouter addtionaljsfichiers en fantôme. Si le fichier n'est pas trouvé dans ledirectory librarypath, la propriété phantom (phantom.libraryPath) est utilisée comme emplacement supplémentaire pour suivre le chemin. Il retournetrue si l'ajout de fichier réussit sinon false en cas d'échec, au cas où il ne parviendrait pas à localiser le fichier.

Syntaxe

Sa syntaxe est la suivante -

phantom.injectJs(filename);

Exemple

Regardons l'exemple suivant pour comprendre l'utilisation de injectJs.

Filename: inject.js

console.log(“Added file”);

File name: addfile.js

var addfile =  injectJs(inject.js);
console.log(addfile);
phantom.exit();

Production

Command - C: \ phantomjs \ bin> phantomjs addfile.js

Added file // coming from inject.js
true

Dans l'exemple ci-dessus, addfile.js appelle le fichier inject.jsen utilisant injectJs. Lorsque vous exécutez addfile.js, le console.log présent dans inject.js est affiché dans la sortie. Cela montre également vrai pour la variable addfile puisque le fichier inject.js a été ajouté avec succès.