PhantomJS - Guide rapide

PhantomJS est dit être un headless browsercar il n'y a aucune implication du navigateur lors de l'exécution du code JavaScript. L'exécution ne sera pas vue dans l'affichage du navigateur, mais sur l'invite de ligne de commande. Les fonctionnalités commeCSS Handling, DOM Manipulation, JSON, Ajax, Canvas, SVG,etc., seront tous pris en charge à l'invite de commande. PhantomJS n'a pas d'interface graphique et par conséquent, toute son exécution a lieu en ligne de commande.

En utilisant PhantomJS, nous pouvons écrire dans un fichier, lire le contenu du fichier ou télécharger un fichier, prendre une capture d'écran, convertir la page Web en pdf et bien plus encore. Avec les navigateurs sans tête, vous obtenez tout le comportement du navigateur, c'est-à-direCookies, Http Request Methods c'est à dire GET /POST, Clearing Cookies, Deleting Cookies, etc., Reloading of Page, Navigating to a Different Page.

PhantomJS utilise WebKit qui a un environnement de navigation similaire à celui des célèbres navigateurs - Google Chrome, Mozilla Firefox, Safari, etc. , interagir avec les pages Web, etc.

PhantomJS ne prend pas en charge Flash ou Vidéo, car il nécessite des plugins et il est difficile de les prendre en charge sur la ligne de commande.

Caractéristiques de PhantomJS

Voyons maintenant les fonctionnalités qu'offre PhantomJS.

Automatisation des pages

PhantomJS vous permet de lire le contenu de la page à l'aide de son API. Cela peut aider à manipuler le DOM, utiliser des bibliothèques externes pour effectuer la tâche requise.

Capture d'écran

PhantomJS aide à prendre une capture d'écran d'une page spécifiée et à enregistrer la même chose comme une image dans divers formats tels que PNG, JPEG, PDF et GIF. Avec l'aide de la capture d'écran, il peut facilement aider à s'assurer que le contenu Web est correct.

PhantomJS propose des propriétés et des méthodes à l'aide desquelles il permet aux développeurs d'ajuster la taille des captures d'écran et de spécifier la zone qu'ils souhaitent capturer.

Test sans tête

PhantomJS aide à tester l'interface utilisateur en ligne de commande. Bien que, à l'aide d'une capture d'écran, cela puisse facilement aider à trouver des erreurs dans l'interface utilisateur. PhantomJS ne peut parfois pas aider à tester seul. Cependant, il peut être emballé avec d'autres bibliothèques de test comme Mocha, Yoeman, etc. Vous pouvez prendre l'aide de PhantomJS pour télécharger un fichier et soumettre le formulaire.

PhantomJS peut être utilisé pour tester les connexions sur les sites et s'assurer que la sécurité n'est pas compromise. PhantomJS peut être utilisé avec d'autres outils commeCasperJS, Mocha, Qunit pour rendre les tests plus puissants.

Surveillance du réseau

L'une des caractéristiques importantes de PhantomJS est son utilisation pour surveiller la connexion réseau à l'aide de l'API disponible. PhantomJS permet l'inspection du trafic réseau; il convient de construire diverses analyses sur le comportement et les performances du réseau.

PhantomJS peut être utilisé pour collecter les données sur les performances de la page Web dans un environnement en direct. PhantomJS peut être utilisé avec des outils commeYslow pour recueillir des mesures de performance de tous les sites Web.

PhantomJS est un logiciel gratuit et est distribué sous le BSD License. Il est facile à installer et offre de multiples fonctionnalités pour exécuter les scripts. PhantomJS peut être facilement exécuté sur plusieurs plates-formes telles que Windows, Linux et Mac.

Pour télécharger PhantomJS, vous pouvez aller sur - http://phantomjs.org/ puis cliquez sur l'option de téléchargement.

Pour les fenêtres

La page de téléchargement vous montre les options de téléchargement pour différents systèmes d'exploitation. Téléchargez le fichier zip, décompressez-le et vous obtiendrez un exécutablephantom.exe. Définissez la variable d'environnement PATH sur le chemin du fichier phantom.exe. Ouvrez une nouvelle invite de commande et tapezphantomjs –v. Il devrait vous donner la version actuelle de PhantomJS en cours d'exécution.

Pour MAC OS X

Téléchargez le fichier zip PhantomJS destiné à MAC OS et extrayez le contenu. Une fois le contenu téléchargé, déplacez le PhantomJS vers -/usr/local/bin/. Exécutez la commande PhantomJS ie phantomjs –v sur le terminal et cela devrait vous donner la description de la version de PhantomJS.

Linux 64 bits

Téléchargez le fichier zip PhantomJS destiné à Linux 64 bits et extrayez le contenu. Une fois le contenu téléchargé, déplacez le dossier PhantomJS vers/usr/local/share/ et create a symlink -

sudo mv $PHANTOM_JS /usr/local/share sudo ln -sf /usr/local/share/$PHANTOM_JS/bin/phantomjs /usr/local/bin.

Exécutez phantomjs –v sur le terminal et il devrait donner la version de PhantomJS.

Linux 32 bits

Téléchargez le fichier zip PhantomJS destiné à Linux 32 bits et extrayez le contenu. Une fois le contenu téléchargé, déplacez le dossier PhantomJS vers/usr/local/share/ et créez un lien symbolique -

sudo mv $PHANTOM_JS /usr/local/share sudo ln -sf /usr/local/share/$PHANTOM_JS/bin/phantomjs /usr/local/bin.

Exécutez phantomjs –v sur le terminal et il devrait donner la version de PhantomJS.

Le code source de PhantomJS peut également être extrait du référentiel git en cliquant sur le lien suivant - https://github.com/ariya/phantomjs/

Pour exécuter des scripts dans PhantomJS, la commande est la suivante -

phantomjs jsfile arg1 arg2…

Dans ce chapitre, nous examinerons les quatre objets importants PhantomJS. Ils sont les suivants -

  • CookiesEnabled
  • Cookies
  • LibraryPath
  • Version

Examinons maintenant chacun de ces éléments en détail.

cookiesEnabled

Il indique si les cookies sont activés ou non. Il reviendratrue, si oui; autrementfalse.

Syntaxe

Sa syntaxe est la suivante -

phantom.cookiesEnabled

Exemple

cookieenabled.js

phantom.addCookie ({  
   //adding cookie with addcookie property 
   name: 'c1', 
   value: '1', 
   domain: 'localhost' 
}); 

console.log("Cookie Enabled value is : "+phantom.cookiesEnabled); 
phantom.exit();

Production

Command - cookie phantomjsenabled.js

Cookie Enabled value is : true

Biscuits

Cela permet d'ajouter et de définir des cookies sur un domaine. Il renvoie un objet avec tous les cookies disponibles pour le domaine.

Syntaxe

Sa syntaxe est la suivante -

phantom.cookies;

Exemple

Filename: phantomcookie.js

phantom.addCookie ({ 
   name: 'c1', 
   value: '1', 
   domain: 'localhost' 
}); 
phantom.addCookie ({ 
   name: 'c2', 
   value: '2', 
   domain: 'localhost' 
}); 
phantom.addCookie ({ 
   name: 'c3', 
   value: '3', 
   domain: 'localhost' 
}); 
console.log(JSON.stringify(phantom.cookies)); 
phantom.exit();

Production

Command - phantomjs phantomcookie.js

[{"domain":".localhost","httponly":false,"name":"c3","path":"/","secure":false, " 
value":"3"},{"domain":".localhost","httponly":false,"name":"c2","path":"/","sec u 
re":false,"value":"2"},{"domain":".localhost","httponly":false,"name":"c1","pat h
":"/","secure":false,"value":"1"}]

Dans l'exemple ci-dessus, nous avons ajouté des cookies au domaine localhost. Nous l'avons ensuite récupéré en utilisantphantom.cookies. Il renvoie un objet avec tous les cookies en utilisant leJSON stringifyméthode pour convertir l'objet JavaScript en une chaîne. Vous pouvez aussi utiliserforeach pour accéder au nom / aux valeurs des cookies.

LibraryPath

PhantomJS libraryPath stocke le chemin du script à utiliser par le injectJS méthode.

Syntaxe

Sa syntaxe est la suivante -

phantom.libraryPath

Exemple

Voici un exemple pour connaître la version.

var webPage = require('webpage');
var page = webPage.create();

page.open('http://www.tutorialspoint.com/jquery', function(status) {
   if (status === "success") { 
      page.includeJs('http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js ', function() { 
         if (page.injectJs('do.js')) { 
            // returnTitle is a function loaded from our do.js file - see below 
            return returnTitle(); 
         });
         
         console.log(title); 
         phantom.exit(); 
      } 
   } 
});

window.returnTitle = function() { 
   return document.title;
};

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

Jquery Tutorial

Version

Il donne la version du PhantomJS en cours d'exécution et renvoie les détails dans un objet. Par exemple: {"major": 2, "minor": 1, "patch": 1}

Syntaxe

Sa syntaxe est la suivante -

phantom.version

Exemple

Voici un exemple pour connaître la version.

var a = phantom.version;
console.log(JSON.stringify(a));
console.log(a.major);
console.log(a.minor);
console.log(a.patch);
phantom.exit();

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

{"major":2,"minor":1,"patch":1} 
2 
1 
1

Dans l'exemple ci-dessus, nous avons utilisé console.logpour imprimer la version. Actuellement, nous fonctionnons sur la version 2. Il renvoie l'objet avec les détails indiqués dans le bloc de code ci-dessus.

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 abordé dans les chapitres suivants.

PhantomJS expose les méthodes suivantes qui peuvent nous aider à exécuter JavaScript sans 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, alors 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.

PhantomJS fournit de nombreuses propriétés et méthodes pour nous aider à interagir avec le contenu d'une page Web.

La commande require ("page Web"). Create () crée un objet de page Web. Nous utiliserons cet objet pour manipuler la page Web à l'aide des propriétés et des méthodes répertoriées ci-dessous.

var wpage = require("webpage").create();

Le tableau suivant contient la liste de toutes les propriétés de page Web dont nous allons parler.

S. Non Propriétés et description
1 canGoBack

Cette propriété renvoie trues'il existe une page précédente dans l'historique de navigation; si non,false.

2 canGoForward

Cette propriété renvoie true s'il existe une page suivante dans l'historique de navigation; si non,false.

3 clipRect

clipRect est un objet avec les valeurs top, left, width et height et utilisé pour prendre la capture d'image de la page Web lorsqu'il est utilisé par la méthode render ().

4 Contenu

Cette propriété contient le contenu de la page Web.

5 biscuits

Avec les cookies, vous pouvez définir / obtenir les cookies disponibles sur l'URL. Il vous donnera également les cookies disponibles sur l'URL et les nouveaux cookies définis sur la page.

6 customHeaders

customHeaders spécifie des en-têtes de requête HTTP supplémentaires qui seront envoyés au serveur pour chaque requête émise par la page.

sept un événement

Il donne une longue liste d'événements, à savoir le modificateur, les détails des touches.

8 focusFrameName

Renvoie le nom de l'image actuellement focalisée.

9 frameContent

Cette propriété donne le contenu du cadre qui est actif.

dix frameName

Renvoie le nom de l'image actuellement focalisée.

11 framePlainText

Cette propriété donne également le contenu du cadre actif actuel, mais uniquement le contenu sans aucune balise html.

12 frameTitle

Donne le titre de l'image active.

13 frameUrl

Cette propriété donnera l'url du cadre actuellement focalisé.

14 framesCount

Donne le nombre de cadres présents sur la page.

15 framesName

Donne un tableau de noms de trames.

16 libraryPath

Cette propriété a le chemin, qui est utilisé par la méthode page.inectJs.

17 navigationLocked

Cette propriété définit si la navigation de la page est autorisée ou non. Si c'est vrai, ce sera sur l'URL de la page actuelle et cliquer sur la page pour aller à la page suivante ne sera pas autorisé.

18 offlineStoragePath

Cette propriété donne le chemin où les données sont stockées à l'aide de window.localStorage. Le chemin peut être modifié à l'aide de --local-storage-path depuis la ligne de commande.

19 offlineStorageQuota

Cette propriété définit la quantité maximale de données que vous pouvez stocker dans window.localStorage.La valeur est de 5242880 octets, soit 5 Mo. Cette valeur peut être écrasée en ligne de commande à l'aide de la commande suivante --localstorage-quota = size over here.

20 possèdePages

ownsPages renvoie true ou false si la page ouverte par la page Web est un enfant de la page Web.

21 pagesWindowName

PagesWindowName donnera les noms des fenêtres ouvertes en utilisant window.open

22 pages

La propriété pages vous donnera un tableau de pages ouvertes dans une page en utilisant window.open. Si la page est fermée dans l'url vous référant la page ne sera pas considérée.

23 taille de papier

Cette propriété donne la taille, c'est-à-dire les dimensions de la page Web lorsque cela doit être utilisé pour convertir la page Web au format PDF.paperSize contient les dimensions requises dans un objet.

24 texte en clair

Cette propriété donne également le contenu du cadre actif actuel, mais uniquement le contenu sans aucune balise html.

25 scrollPosition

Celui-ci contient un objet indiquant la position de défilement. Il donne gauche et haut.

26 réglages

Cette propriété donnera les paramètres de la page Web lorsque la méthode page.open est utilisée. Une fois la page chargée, les modifications apportées aux propriétés des paramètres n'auront aucun impact.

27 Titre

Cette propriété vous donnera le titre de la page que vous lisez.

28 URL

Cette propriété donnera l'URL de la page.

29 viewportSize

Cette propriété permet de changer la taille de l'affichage de la fenêtre. Il contient la largeur et la hauteur, que vous pouvez lire ou modifier selon les besoins.

30 windowName

Donne le nom de la fenêtre.

31 zoomFactor

Cette propriété spécifie le facteur de zoom pour les méthodes render et renderBase64. Il permet de zoomer une page et de prendre une capture d'écran si nécessaire.

Le module de page Web a des méthodes pour Cookies, Frames, Page Navigation, Reload, Rendering et Uploading of Files.

Voici les méthodes disponibles sur la page Web.

S. Non Méthodes et description
1 addCookie ()

La méthode addCookie ajoute des cookies à la page spécifiée.

2 childFramesCount()

Cette méthode est obsolète selon http://phantomjs.org.

3 childFramesName()

Cette méthode est obsolète selon http://phantomjs.org.

4 effacer les cookies()

Supprimera tous les cookies de la page spécifiée.

5 Fermer()

Cette méthode est utilisée pour fermer la page et libérer la mémoire utilisée. Aucune des méthodes ou propriétés de la page Web ne fonctionnera une fois la fermeture appelée.

6 currentFrameName()

Cette méthode est obsolète selon http://phantomjs.org.

sept deleteCookie ()

Cela supprimera un cookie dont le nom correspond à la liste existante de cookies présents pour une URL de page donnée.

8 évaluerAsync ()

Évaluez la fonction donnée de manière asynchrone dans la page sans bloquer l'exécution en cours. Cette fonction permet d'exécuter certains scripts de manière asynchrone.

9 évaluerJavascript ()

EvaluateJavaScript aide à exécuter la fonction qui lui est passée sous forme de chaîne. Veuillez noter que la chaîne transmise doit être une fonction uniquement.

dix évaluer()

Evaluate exécutera la fonction qui lui est passée. Si la fonction contient des messages de console, elle n'est pas affichée directement dans le terminal. Pour afficher les messages de la console, vous devez utiliser le rappel fantôme onConsoleMessage.

11 getPage ()

Cela vous donnera la page enfant qui correspond au nom de fenêtre passé dans getpage.

12 retourner()

Il donne la page précédente de l'historique de navigation, si seule la navigation n'est pas verrouillée.

13 aller de l'avant()

Il donne la page suivante de l'historique de navigation, si seule la navigation n'est pas verrouillée.

14 aller()

Cette méthode vous permet de naviguer avec les pages.

15 includeJs ()

Includejs exécute le fichier JS externe sur la page et exécute la fonction de rappel à la fin.

16 injectJs ()

InjectJs inclut un script externe à partir d'un fichier spécifié dans la page. Si le fichier n'est pas disponible dans le répertoire courant, il a utilisé libraryPath pour une recherche supplémentaire du fichier. Il renvoie true si le fichier est injecté, sinon false.

17 ouvrir le lien()

OpenUrl ouvre une page Web. C'est similaire à la méthode ouverte de PhantomJS. OpenUrl a quelques paramètres supplémentaires, qui sont httpConf, les paramètres et les fonctions de rappel.

18 ouvert()

Ouvrir est utilisé pour ouvrir une page Web.

19 Libération()

Release libérera l'utilisation du tas de mémoire pour la page. N'utilisez pas de méthodes d'instance de page après l'appel de la version. Cette méthode est similaire à la méthode close et son utilisation est obsolète. Utilisez plutôt wpage.close ().

20 recharger()

Recharger est utilisé pour recharger la page actuellement utilisée.

21 renderBase64 ()

Cette méthode prend la capture d'écran et donne l'image sous forme de chaîne en base46. Renderbase64 prend en charge les formats tels que PNG, JPEG et JPG. Il ne prend pas en charge les gif pour le moment. Vous pouvez utiliser la propriété clipRect pour définir la partie pour la capture d'image.

22 renderBuffer ()

RenderBuffer prend la capture de la page Web dans un tampon d'image, qui peut être directement envoyé au serveur. Les formats pris en charge sont PNG, GIF et JPEG.

23 rendre()

Render permet de prendre le tampon d'image et de l'enregistrer selon le format spécifié.

24 sendEvent ()

Il est utilisé pour envoyer un événement sur la page Web. Ce ne sont pas des événements dom. Chacun de ces événements est envoyé à la page Web en fonction de l'interaction de l'utilisateur.

25 setContent ()

setcontent changera le contenu de la page de l'URL spécifiée avec le contenu spécifié.

26 Arrêtez()

Cela aide à arrêter le chargement de la page.

27 switchToChildFrame()

Il est déconseillé d'utiliser switchToFrame ();

28 switchToFocusedFrame ()

Il sélectionne le cadre qui est mis au point.

29 switchToFrame ()

Sélectionne l'image avec le nom spécifié et qui est l'enfant de l'image courante.

30 switchToMainFrame ()

Sélectionne le mainframe, c'est-à-dire la fenêtre racine.

31 switchToParentFrame ()

Il prend l'image parente de l'image enfant actuelle.

32 téléverser un fichier()

Cette méthode est utilisée pour gérer le téléchargement de fichiers effectué à l'aide d'un formulaire en html. PhantomJS n'a pas de moyen direct de le faire en utilisant des formulaires, la même chose peut être obtenue en utilisant la méthode uploadFile. Il faut un sélecteur de balises html pour l'emplacement du fichier et la destination où il doit être copié.

Les rappels disponibles avec le module de page Web sont décrits dans le tableau suivant.

S. Non Rappels et description
1 en alerte()

Ce rappel est appelé lorsqu'il y a une alerte sur la page; le rappel prend une chaîne et ne renvoie rien.

2 onCallback ()

OnCallback est utilisé pour passer des valeurs d'une page Web à un objet de page Web et cela se fait à l'aide de la méthode window.callPhantom (), qui appelle en interne la fonction onCallback.

3 onClosing ()

Ceci est appelé lorsque la fenêtre est fermée à l'aide de la méthode page.close () ou de la méthode window.close ().

4 onConfirm ()

Ce rappel est appelé lorsqu'il y a un message confirmé appelé avec ok / cancel depuis la page.

5 onConsoleMessage ()

Ce rappel est utilisé lorsque des messages de console sont utilisés dans la page Web. La méthode onConsoleMessage prend 3 arguments.

6 onError ()

Il est appelé en cas d'erreur JavaScript. Les arguments pour onError sont msg et stack trace, qui est un tableau.

sept onFilePicker ()

Ceci est utilisé pour télécharger le fichier, le rappel est appelé lorsque l'utilisateur souhaite télécharger un fichier.

8 onInitialized ()

Ce rappel est appelé lorsque la page est appelée avant le chargement.

9 onLoadFinished ()

Cette fonction est appelée lorsque la page ouverte est complètement chargée. Il a un argument, qui indique quand le chargement a été un succès ou un échec.

dix onLoadStarted ()

Ce rappel est appelé lorsque la page commence à se charger.

11 onNavigationRequested ()

Ce rappel indique quand l'événement de navigation a lieu.

12 onPageCreated ()

Ce rappel est appelé lorsqu'une nouvelle fenêtre enfant est ouverte par la page.

13 onPrompt ()

Ce rappel est appelé lorsqu'une invite est appelée par la page Web. Il faut 2 arguments, un message et la réponse. La valeur de retour est une chaîne.

14 onResourceError ()

Ce rappel est appelé lorsque la page Web n'est pas en mesure de télécharger le fichier.

15 onResourceReceived ()

Ce rappel est appelé lorsque la ressource demandée par la page est reçue.

16 onResourceRequested ()

Cette fonction est appelée lorsque la page demande une ressource.

17 onResourceTimeout ()

Ce rappel est appelé lorsque la ressource demandée expire, lorsque settings.resourceTimeout est utilisé.

18 onUrlChanged ()

Ceci est appelé lorsque l'URL change de l'URL actuelle à l'aide de la navigation. Il a un argument pour le rappel, qui est une nouvelle chaîne URL targetUrl.

Le module de processus Phantomjs Child permet d'interagir avec les sous-processus et de leur parler en utilisant stdin /stdout/stderr. Les processus enfants peuvent être utilisés pour des tâches telles queprinting, sending mail ou pour invoke programsécrit dans une autre langue. Pour créer un module de processus enfant, vous avez besoin de références.

Par exemple -

var process = require("child_process");

Méthode de spawn

Avec le processus enfant spawn, vous pouvez vous abonner à son stdout et stderr flux pour obtenir des données en temps réel.

Syntaxe

Sa syntaxe est la suivante -

var spawn = require('child_process').spawn;

Exemple

Regardons un exemple de la méthode spawn.

var process = require("child_process")
var spawn = process.spawn
var child = spawn("cmd", ['/c', 'dir']);

child.stdout.on("data", function (data) {
   console.log("spawnSTDOUT---VALUE:", JSON.stringify(data))
})
child.stderr.on("data", function (data) {
   console.log("spawnSTDERR:", JSON.stringify(data))
})
child.on("exit", function (code) {
   console.log("spawnEXIT:", code)
})

Production

Le programme ci-dessus génère la sortie suivante.

spawnSTDOUT---VALUE: " Volume in drive C is OS\r\n"
spawnSTDOUT---VALUE: " Volume Serial Number is 7682-9C1B\r\n\r\n Directory of C:
\\phantomjs\\bin\r\n\r\n"
spawnSTDOUT---VALUE: "20-05-2017  10:01
<DIR>          .\r\n20-05-2017  10:01
<DIR>          ..\r\n13-05-2017  20:48   12 a,txt.txt\r\n07-05-2017  08:51
63 a.js\r\n06-05-2017  16:32           120,232 a.pdf\r\n13-05-2017  20:49 
spawnEXIT: 0

Le module de système de fichiers possède de nombreuses API pour gérer les fichiers et les répertoires. Vous pouvez créer / écrire et supprimer un fichier / répertoire. Pour commencer à utiliser le module du système de fichiers, vous devez avoir besoin d'une référence aufs module.

var fs = require('fs');

Deux propriétés sont disponibles pour le module de système de fichiers: Separator et Working Directory. Comprenons-les en détail.

Séparateur

Il vous indique le séparateur utilisé pour les chemins de fichiers.

  • Pour les fenêtres:\
  • Pour Linux: /

Syntaxe

Sa syntaxe est la suivante -

fs.seperator

Exemple

var fs = require('fs');
console.log(fs.seperator);
phantom.exit();

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

undefined

directeur de travail

Le répertoire de travail est le répertoire dans lequel PhantomJS s'exécute.

Syntaxe

Sa syntaxe est la suivante -

var fs = require('fs');
fs.workingDirectory;

Exemple

var fs = require('fs');
console.log(fs.workingDirectory);
phantom.exit();

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

C:/phantomjs/bin

Le tableau suivant présente toutes les méthodes et leurs descriptions, disponibles dans le module Système de fichiers.

S. Non Méthodes et description
1 absolu

Cette méthode donne le chemin absolu où s'exécute PhantomJS.

2 changeWorkingDirectory

Cela vous permet de changer le répertoire de travail et retourne true, si cela réussit, sinon retourne false.

3 copyTree

copyTree copiera un répertoire d'un chemin vers un autre. Le premier paramètre est un dossier source et le deuxième paramètre est un dossier de destination.

4 copie

Cette méthode permet de copier le fichier d'un emplacement à un autre. Cela prend deux paramètres. Le premier paramètre est le fichier source et le deuxième paramètre est le chemin du fichier, où il doit être copié. Il lancera une erreur si le fichier source ou de destination n'existe pas.

5 existe

Il vérifie si le chemin de fichier donné existe dans le système. Il renvoie vrai, s'il est présent, sinon faux.

6 isAbsolue

Cette méthode retournera true si le chemin du fichier est absolu et false s'il est relatif.

sept isDirectory

isDirectory indique si le fichier donné est un répertoire ou non. Il renvoie true, si le répertoire est sinon false. Il donne false si le chemin donné n'existe pas.

8 isExecutable

Cette méthode dira si le fichier donné est exécutable ou non. Il renvoie vrai, s'il est exécutable, sinon faux.

9 isFile

Cela donne des détails si le chemin de fichier indiqué est un fichier ou non. Il renvoie true, s'il s'agit d'un fichier et false, si ce n'est pas le cas.

dix isLink

Cela vous donnera vrai, si le chemin du fichier est un lien symbolique, sinon faux.

11 isLisible

Il vérifie si le fichier donné est lisible ou non. Cela donne vrai, si oui et faux, sinon.

12 isWritable

Il indique si un fichier donné est accessible en écriture. Renvoie vrai, si oui, sinon faux.

13 lastModified

Donne les détails de la dernière modification apportée au fichier. Il indique la date et l'heure de la dernière modification du fichier.

14 liste

Il donne tous les fichiers présents dans le répertoire.

15 makeDirectory

Crée un nouveau répertoire.

16 makeTree

makeTree crée tous les dossiers nécessaires pour pouvoir former des répertoires finaux. Cela retournera vrai si la création a réussi, sinon faux. Si le répertoire existe déjà, il retournera true.

17 bouge toi

Cela déplacera le fichier d'un chemin à un autre.

18 ouvert

Il est utilisé pour ouvrir le fichier.

19 readLink

Cela renverra le chemin absolu d'un fichier ou d'un dossier pointé par un lien symbolique (ou un raccourci sous Windows). Si le chemin n'est pas un lien symbolique ou un raccourci, il renverra une chaîne vide.

20 lis

Cela lira le fichier donné.

21 removeDirectory

Cela supprimera le répertoire donné.

22 removeTree

Il supprimera tous les fichiers et dossiers du dossier donné et supprimera finalement le dossier lui-même. S'il y a une erreur lors de ce processus, il lancera une erreur - «Impossible de supprimer l'arborescence de répertoires PATH» et suspendra l'exécution.

23 retirer

Il supprime le fichier donné.

24 Taille

Il donne la taille du fichier.

25 toucher

Il crée un fichier donné.

26 écrire

Écrit dans un fichier donné.

Dans ce chapitre, nous aborderons les différentes propriétés du module système de PhantomJS.

args

Le module système de PhantomJS a différentes propriétés, qui aident à passer des arguments, à connaître le fichier qui est exécuté, etc.

La propriété args renvoie essentiellement les arguments passés en ligne de commande. Vous pouvez également transmettre l'URL de la page que vous souhaitez lire. Si vous souhaitez stocker le fichier pdf de capture d'écran ou télécharger le fichier, les détails peuvent être transmis à la ligne de commande et peuvent être lus à l'aide duargs propriété.

Trouvons la longueur et la manière de récupérer chaque argument passé à la ligne de commande.

Syntaxe

Sa syntaxe est la suivante -

var system = require('system'); 
system.args;

Exemple

Jetez un œil à l'exemple suivant pour comprendre le fonctionnement de cette propriété.

var system = require('system');
console.log(system.args.length);

if (system.args.length>0) {
   console.log(JSON.stringify(system.args));
}
phantom.exit();

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

Command - phantomsjs args.js http://localhost/tasks/request.html

2
["args.js","http://localhost/tasks/request.html"]

La première valeur est le nom du fichier et la valeur suivante est l'URL transmise. Vous pouvez passer plus d'arguments dans la ligne de commande et récupérer les mêmes en utilisantsystem.args.

env

le env property renvoie les détails du système.

Syntaxe

Sa syntaxe est la suivante -

var system = require('system'); 
system.env;

Exemple

var system = require('system'); 
console.log(JSON.stringify(system.env)); 
phantom.exit();

Le programme ci-dessus génère la sortie suivante.

{"=::":"::\\","=C:":"C:\\phantomjs\\bin","=ExitCode":"00000000","ALLUSERSPROFILE":
"C:\\ProgramData","APPDATA":"C:\\Users\\UserName\\AppData\\Roaming","COMPUTERNAME":
"X","ComSpec":"C:\\Windows\\system32\\cmd.exe","CommonProgramFiles":
"C:\\Program Files (x86)\\Common Files","CommonProgramFiles(x86)":
"C:\\Program Files (x86)\\Common Files","CommonProgramW6432":
"C:\\Program Files\\Common Files","FP_NO_HOST_CHECK":"NO","HOMEDRIVE":"C:",
"HOMEPATH":"\\Users\\UserName","LOCALAPPDATA":
"C:\\Users\\UserName\\AppData\\Local","LOGONSERVER":"\\\\MicrosoftAccount",
"NUMBER_OF_PROCESSORS":"2","OS":"Windows_NT","PATHEXT":".COM;.EXE;.BAT;.CMD;.VBS ;
.VBE;.JS;.JSE;.WSF;.WSH;.MSC","PROCESSOR_ARCHITECTURE":"x86","PROCESSOR_ARCHITEW64 32":
"AMD64","PROCESSOR_IDENTIFIER":"Intel64 Family 6 Model 58Stepping9,GenuineIntel",
"PROCESSOR_LEVEL":"6","PROCESSOR_REVISION":"3a09","PROMPT":
"$P$G","PSModulePath":"C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\
Modules\\" ,"PUBLIC":"C:\\Users\\Public","Path":
"C:\\Program Files\\Dell\\DW WLAN Card;
c:\\Program Files (x86)\\Intel\\iCLS Client\\;c:\\Program Files\\Intel\\iCLSClient\\;
C:\\Windows\\system32;C:\\Windows;C:\\Windows\\System32\ \Wbem;
C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;
C:\\Program Files\\Intel\\Intel(R) Management Engine Components\\DAL;
C:\\Program Files\\Intel\\Intel(R) Management Engine Components\\IPT;
C:\\Program Files (x86)\\Intel\\Intel(R) Management Engine Components\\DAL;
C:\\Program Files (x86)\\Intel\\Intel(R) 
ManagementEngineComponents\\IPT;c:\\ProgramFiles\\WIDCOMM\\BluetoothSoftware\\;
c:\\ProgramFiles\\WIDCOMM\\BluetoothSoftware\\syswow64;
C:\\ProgramFiles(x86)\\WindowsLive\\Shared;C:\\ProgramFiles\\nodejs\\;
C:\\ProgramFiles\\Git\\cmd;C:\\ProgramFiles\\ OpenVPN\\bin;
C:\\ProgramFiles(x86)\\Skype\\Phone\\;C:\\Users\\UserName\\AppData\\Roaming
\\npm","ProgramData":
"C:\\ProgramData","ProgramFiles":"C:\\ProgramFiles(x86)", 
"ProgramFiles(x86)":"C:\\ProgramFiles(x86)","ProgramW6432":
"C:\\ProgramFiles","SESSIONNAME":"Console","SystemDrive":
"C:","SystemRoot":"C:\\Windows","TEMP":"C:\\Users\ \Username~1\\AppData\\Local\\Temp",
"TMP":"C:\\Users\\Username~1\\AppData\\Local\\Temp",
"USERDOMAIN":"USER","USERDOMAIN_ROAMINGPROFILE":"USER","USERNAME":"X Y","USERPROFILE":
"C:\\Users\\X Y","windir":"C:\\Windows"}

OS

Il renvoie les détails du système d'exploitation utilisé. Il renvoie un objet avec l'architecture, le nom du système d'exploitation et la version.

Syntaxe

Sa syntaxe est la suivante -

var system = require('system');
system.os;

Exemple

var system = require('system');
console.log(JSON.stringify(system.os));
phantom.exit();

Le programme ci-dessus génère la sortie suivante.

{"architecture":"32bit","name":"windows","version":"8.1"}

pid

Cette propriété renvoie l'ID de processus.

Syntaxe

Sa syntaxe est la suivante -

var system = require('system');
system.pid;

Exemple

Prenons un exemple de la pid propriété.

var system = require('system');
console.log(system.pid);
phantom.exit();

Le programme ci-dessus génère la sortie suivante.

2160

Plate-forme

Cette propriété renvoie la plateforme sur laquelle nous travaillons.

Syntaxe

Sa syntaxe est la suivante -

var system = require('system');
system.platform;

Exemple

var system = require('system');
console.log(system.platform);
phantom.exit();

Le programme ci-dessus génère la sortie suivante.

Phantomjs

PhantomJS utilise un serveur Web intégré appelé mongoose. À l'heure actuelle, PhantomJS ne peut se connecter à aucun autre serveur Web de production. En ce qui concerne la connexion, il peut traiter 10 connexions à la fois et plus de 10 demandes seront en attente dans une file d'attente.

Pour démarrer un serveur Web, nous devons utiliser la syntaxe suivante -

var webserver = require (‘webserver’);

Laissez-nous comprendre le Port property, qui est utilisée pour écouter les requêtes envoyées au serveur Web.

Port

La propriété Port d'un serveur Web est utilisée pour écouter la demande qui lui est envoyée.

Syntaxe

Sa syntaxe est la suivante -

var server = require('webserver').create();
var listening = server.listen(port, function (request, response) {});

Exemple

Prenons un exemple pour comprendre comment le port la propriété fonctionne.

var webserver = require('webserver'); 
var server = webserver.create(); 
var service = server.listen(8080,function(request,response){  
}); 
if(service) console.log("server started - http://localhost:" + server.port);

Le programme ci-dessus génère la sortie suivante.

server started - http://localhost:8080

Dans ce chapitre, nous discuterons des différentes méthodes du module serveur Web de PhantomJS.

Fermer

le close méthode est utilisée pour fermer le serveur Web.

Syntaxe

Sa syntaxe est la suivante -

var server = require('webserver').create();
server.close();

Exemple

L'exemple suivant montre comment utiliser le close méthode.

var webserver = require('webserver');
var server = webserver.create();
var service = server.listen(8080,function(request,response){
});

if(service) console.log("server started - http://localhost:" + server.port);
console.log(server.port);
server.close();
console.log(server.port);

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

server started - http://localhost:8080 
8080

Ici, nous avons consolé server.portaprès avoir fermé le serveur. Par conséquent, il ne répondra pas, car le serveur Web est déjà fermé.

Ecoutez

le server.listen La méthode prend le port et la fonction de rappel avec deux arguments, qui sont - Request Object et Response Object.

le Request Object contient les propriétés suivantes -

  • Method - Ceci définit la méthode GET / POST.

  • URL - Cela affiche l'URL demandée.

  • httpVersion - Ceci affiche la version http réelle.

  • Headers - Cela affiche tous les en-têtes avec des paires clé / valeur.

  • Post - Corps de la requête applicable uniquement pour la méthode post.

  • postRaw - Si l'en-tête Content-Type est défini sur `` application / x-www-formurlencoded '', le contenu original du message sera stocké dans cette propriété supplémentaire (postRaw), puis ce message sera automatiquement mis à jour avec une version décodée par URL des données.

le Response Object contient les propriétés suivantes -

  • Headers- A tous les en-têtes HTTP sous forme de paires clé-valeur. Il doit être défini avant d'appeler write pour la première fois.

  • SetHeader - Ceci définit un en-tête spécifique.

  • Header (name) - Il renvoie la valeur de l'en-tête donné.

  • StatusCode - Il définit le code d'état HTTP renvoyé.

  • SetEncoding (encoding)- Ceci est utilisé pour convertir les données fournies à write (). Par défaut, les données seront converties en UTF-8. Indiquez «binaire» si les données sont une chaîne binaire. Non requis si les données sont un tampon (par exemple à partir de page.renderBuffer).

  • Write (data)- Il envoie des données pour le corps de la réponse. Peut être appelé plusieurs fois.

  • WriteHead (statusCode, headers)- Il envoie un en-tête de réponse à la demande. Le code d'état est un code d'état HTTP à 3 chiffres (par exemple 404). Les derniers arguments et en-têtes sont les en-têtes de réponse.

  • Close - Il ferme la connexion http.

  • CloseGracefully - Il est similaire à close (), mais il s'assure que les en-têtes de réponse ont été envoyés en premier.

Syntaxe

Sa syntaxe est la suivante -

var server = require('webserver').create(); 
var listening = server.listen(8080, function (request, response) {}

Exemple

Prenons un exemple pour comprendre comment le listen la méthode fonctionne.

var page = require('webpage').create(); 
var server = require('webserver').create(); 
var port = 8080; 
var listening = server.listen(8080, function (request, response) { 
   console.log("GOT HTTP REQUEST"); 
   console.log(JSON.stringify(request, null, 4)); 
   
   // we set the headers here 
   response.statusCode = 200; 
   response.headers = {"Cache": "no-cache", "Content-Type": "text/html"};  
 
   // the headers above will now be sent implictly 
   // now we write the body 
   response.write("<html><head><title>Welcone to Phantomjs</title></head>"); 
   response.write("<body><p>Hello World</p></body></html>"); 
   response.close(); 
}); 

if (!listening) { 
   console.log("could not create web server listening on port " + port); 
   phantom.exit(); 
} 

var url = "http://localhost:" + port + "/foo/response.php"; 
console.log("sending request to :" +url); 
page.open(url, function (status) { 
   if (status !== 'success') { 
      console.log('page not opening'); 
   } else { 
      console.log("Getting response from the server:"); 
      console.log(page.content); 
   } 
   
   phantom.exit(); 
});

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

sending request to :http://localhost:8080/foo/response.php 
GOT HTTP REQUEST { 
   "headers": {
      "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8", 
      "Accept-Encoding": "gzip, deflate", 
      "Accept-Language": "en-IN,*", 
      "Connection": "Keep-Alive", 
      "Host": "localhost:8080", 
      "User-Agent": "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 
         (KHTML, like Gecko) PhantomJS/2.1.1 Safari/538.1" 
   }, 
   "httpVersion": "1.1", 
   "method": "GET", 
   "url": "/foo/response.php" 
} 
Getting response from the server: 
<html><head><title>Welcone to Phantomjs</title></head><body><p>Hello World</p></body>
</html>

PhantomJS peut être exécuté en utilisant le mot-clé "phantomjs" et le nom du fichier. Par exemple, "phantomjs file.js".

Vous pouvez également passer des arguments dans "file.js" comme suit -

phantomjs [options] file.js arg1 arg2 ...

Passons en revue certaines des options disponibles sur la ligne de commande.

S. Non Option et description
1

--help or –h

Affiche toutes les options de ligne de commande. S'arrête immédiatement et n'exécutera pas le script passé.

2

--version or –v

Imprime la version de PhantomJS en cours d'exécution. Cela arrêtera l'exécution du script à exécuter.

3

--debug[true|false]

Imprime les avertissements et les messages de débogage. Par défaut, il est défini sur false. Vous pouvez également utiliser [yes | no].

4

--cookies-file = /path/to/cookies.txt

Nom de fichier pour stocker les cookies persistants.

5

--diskcache=[true|false]

Active le cache disque. Il prend également des valeurs [yes | no]

6

--disk-cahe-path

Chemin du cache disque.

sept

--ignore-sslerrors=[true|false]

Ignorez les erreurs SSL. Par exemple - Erreurs de certificat expiré ou auto-signé. La valeur par défaut est false. Il prend également les valeurs [yes | no].

8

--loadimages=[true|false]

Charge toutes les images en ligne. La valeur par défaut est true. Il faut aussi [oui | non].

9

--local-storagepath=/some/path

Chemin pour enregistrer le contenu LocalStorage et le contenu WebSQL.

dix

--local-storagequota=number

Taille maximale pour autoriser les données.

11

--local-url-access

Permet l'utilisation des URL 'file: ///' (la valeur par défaut est true).

12

--local-to-remote-urlaccess=[true|false]

Permet au contenu local d'accéder à l'URL distante. La valeur par défaut est false. Il prend également les valeurs [yes | no].

13

--max-disk-cachesize=size

Limite la taille du cache disque (en Ko)

14

--offline-storage-path

Spécifie l'emplacement du stockage hors ligne.

15

--offline-storage-quota

Définit la taille maximale du stockage hors ligne en Ko.

16

--outputencoding=encoding

Définit le codage utilisé pour la sortie du terminal. La valeur par défaut est utf-8.

17

--proxy=address:port

Spécifie le serveur proxy à utiliser (par exemple - proxy = 192.168.1.1: 8080)

18

--proxytype=[http|socks5|none]

Spécifie le type de serveur proxy (la valeur par défaut est http)

19

--proxy-auth

Informations d'authentification pour le proxy. Par exemple -

--proxy-auth = nom d'utilisateur: mot de passe

20

--scriptencoding=encoding

Définit l'encodage utilisé pour le script. La valeur par défaut est utf8.

21

--script-language

Définit la langue du script.

PhantomJS est très utile pour prendre une capture d'écran d'une page Web et convertir une page Web en PDF. Nous avons donné ici un exemple simple pour montrer comment cela fonctionne.

Exemple

var page = require('webpage').create();
page.open('http://phantom.org/',function(status){
   page.render('phantom.png');
   phantom.exit();
});

Exécutez le programme ci-dessus et la sortie sera enregistrée sous phantom.png.

Convertir des pages Web en PDF

PhantomJS aide également à convertir des pages Web en PDF avec en-tête et pied de page ajoutés. Jetez un œil à l'exemple suivant pour comprendre comment cela fonctionne.

var wpage = require('webpage').create(); 
var url = "https://en.wikipedia.org/wiki/Main_Page"; 
var output = "test.pdf"; 

wpage.paperSize = { 
   width: screen.width+'px', 
   height: '1500px', 
   
   margin: {
      'top':'50px', 
      'left':'50px', 
      'rigtht':'50px' 
   }, 
   orientation:'portrait', 
   header: { 
      height: "1cm", 
      contents: phantom.callback(function(pageNumber, nPages) { 
         return "<h5>Header <b>" + pageNumber + " / " + nPages + "</b></h5>"; 
      }) 
   }, 
   footer: { 
      height: "1cm", 
      contents: phantom.callback(function(pageNumber, nPages) {   
         return "<h5>Footer <b>" + pageNumber + " / " + nPages + "</b></h5>"; 
      }) 
   } 
} 
wpage.open(url, function (status) { 
   if (status !== 'success') { 
      console.log('Page is not opening'); 
      phantom.exit(); 
   } else { 
      wpage.render(output); 
      phantom.exit();     
   } 
});

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

The above will convert the page into pdf and will be saved in test.pdf

Convertir un canevas en image

Phantomjs peut facilement convertir un canevas en image. Jetez un œil à l'exemple suivant pour comprendre comment cela fonctionne.

var page = require('webpage').create(); 
page.content = '<html><body><canvas id="surface" width="400" height="400"></canvas></body></html>'; 

page.evaluate(function() {
   var context,e1; 
   el = document.getElementById('surface'); 
   
   context = el.getContext('2d'); 
   context.font = "30px Comic Sans MS"; 
   context.fillStyle = "red"; 
   context.textAlign = "center"; 
   context.fillText("Welcome to PhantomJS ", 200, 200); 
   
   document.body.style.backgroundColor = 'white'; 
   document.body.style.margin = '0px'; 
}); 
page.render('canvas.png'); 
phantom.exit();

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

PhantomJS, à l'aide de ses API de module de page Web, peut manipuler des pages Web et effectuer des opérations telles que la manipulation DOM, en cliquant sur des boutons, etc.

Récupérer des images d'une page

Le programme suivant montre comment utiliser PhantomJS pour récupérer des images d'une page.

var wpage = require('webpage').create();
wpage.onConsoleMessage = function(str) {
   console.log(str.length);
}
wpage.open("http://phantomjs.org", function(status) {
   console.log(status);
   var element = wpage.evaluate(function() {
      var imgdata =  document.querySelectorAll('img');
      var imgsrc = [];
      
      if (imgdata) {
         for (var i in imgdata) {
            imgsrc.push(imgdata[0].src);
         }
      }
      return imgsrc;
   });
   console.log(JSON.stringify(element));
});

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

Success 
["http://phantomjs.org/img/phantomjslogo.png","http://phantomjs.org/img/phantom 
js-logo.png","http://phantomjs.org/img/phantomjslogo.png","http://phantomjs.org 
/img/phantomjs-logo.png"]

Il est possible d'inclure du JavaScript externe dans une page en utilisant le injectJS webpage method. Il existe de nombreuses propriétés et méthodes qui peuvent aider à l'automatisation des pages et faire beaucoup d'autres choses. Vous pouvez vous référer au module de page Web où les propriétés et les méthodes sont expliquées en détail.

Avec l'aide de PhantomJS, nous pouvons surveiller le réseau et valider le comportement et les performances d'une page Web particulière. Il y a des rappels dans PhantomJS, c'est-à-direonResourceRequested et onResourceReceived, qui aident à surveiller le trafic pour une page donnée.

Exemple

L'exemple suivant montre comment vous pouvez utiliser PhantomJS pour surveiller le trafic pour une page donnée.

function createHAR(address, title, startTime, resources) {  
   
   // this function formats the data which is coming from 
      onresourcerequest and onresourcereceived 
   var entries = []; 
   
   resources.forEach(function (resource) { 
      var request = resource.request, startReply = resource.startReply, 
         endReply = resource.endReply;  
      
      if (!request || !startReply || !endReply) { 
         return; 
      }  
      
      // Exclude Data URI from HAR file because 
      // they aren't included in specification 
      if (request.url.match(/(^data:image\/.*)/i)) { 
         return; 
      }  
      entries.push ({ 
         startedDateTime: request.time.toISOString(), 
         time: endReply.time - request.time, 
         
         request: { 
            method: request.method, 
            url: request.url, 
            httpVersion: "HTTP/1.1", 
            cookies: [], headers: request.headers, 
            queryString: [], 
            headersSize: -1, 
            bodySize: -1 
         }, 
         response: { 
            status: endReply.status, 
            statusText: endReply.statusText, 
            httpVersion: "HTTP/1.1", 
            cookies: [], 
            headers: endReply.headers, 
            redirectURL: "", 
            headersSize: -1, 
            bodySize: startReply.bodySize, 
            
            content: { 
               size: startReply.bodySize, 
               mimeType: endReply.contentType 
            } 
         }, 
         cache: {}, 
         timings: { 
            blocked: 0, 
            dns: -1, 
            connect: -1, 
            send: 0, 
            wait: startReply.time - request.time, 
            receive: endReply.time - startReply.time, 
            ssl: -1 
         }, 
         pageref: address 
      }); 
   });  
   return { 
      log: { 
         version: '1.2', creator: { 
            name: "PhantomJS", 
            version: phantom.version.major + '.' + phantom.version.minor + 
               '.' + phantom.version.patch 
         }, 
         pages: [{ 
            startedDateTime: startTime.toISOString(), 
            id: address, 
            title: title, 
            
            pageTimings: { 
               onLoad: page.endTime - page.startTime 
            } 
         }], 
         entries: entries 
      } 
   }; 
}  
var page = require('webpage').create(), system = require('system'); 
var fs = require('fs');   

if (system.args.length === 1) { 
   console.log('Usage: netsniff.js <some URL>'); 
   phantom.exit(1); 
} else { 
   page.address = system.args[1]; 
   page.resources = []; 
   
   page.onLoadStarted = function () {  // called when page is loaded 
      page.startTime = new Date(); 
   };  
   page.onResourceRequested = function (req) {  
      // called when any files are requested from given page url 
      page.resources[req.id] = { 
         request: req, 
         startReply: null, 
         endReply: null 
      }; 
   };  
   page.onResourceReceived = function (res) {  
      //called when any files are received. 
      if (res.stage === 'start') { 
         page.resources[res.id].startReply = res; 
      } 
      if (res.stage === 'end') { 
         page.resources[res.id].endReply = res; 
      } 
   };  
   page.open(page.address, function (status) {  // open given page url 
      var har; 
      
      if (status !== 'success') { 
         console.log('FAIL to load the address'); 
         phantom.exit(1); 
      } else { 
         page.endTime = new Date(); 
         
         page.title = page.evaluate(function () { // gets the page title 
            return document.title; 
         });             
         har = createHAR(page.address, page.title, page.startTime, page.resources);  
         
         // calls the function createHAR with page url, starttime, and page resources. 
         // console.log(JSON.stringify(har, undefined, 4)); 
         fs.write('log.txt', JSON.stringify(har, undefined, 4), 'w');  
         
         // logs are collected in log.txt file. 
         phantom.exit(); 
      } 
   }); 
}

Exemple de log.txt donné à l'aperçu HAR

{ 
   "log": { 
      "version": "1.2", 
      "creator": { 
         "name": "PhantomJS", 
         "version": "2.1.1" 
      }, 
      "pages": [ 
         { 
            "startedDateTime": "2017-05-21T13:41:21.824Z", 
            "id": "http://www.sample.com", 
            "title": "Free Sample Products – Sample.com ≫ Free Samples, 
               Free Product Samples, Product Test Marketing", 
            "pageTimings": { 
               "onLoad": 11081 
            } 
         } 
      ], 
      "entries": [ 
         { 
            "startedDateTime": "2017-05-21T13:41:21.815Z", 
            "time": 1999, 
            
            "request": { 
               "method": "GET", 
               "url": "http://www.sample.com/", 
               "httpVersion": "HTTP/1.1", 
               "cookies": [], 
               
               "headers": [ 
                  { 
                     "name": "Accept", 
                     "value": "text/html,application/xhtml+xml,
                        application/xml;q = 0.9,*/*;q = 0.8" 
                  }, 
                  
                  { 
                     "name": "User-Agent", 
                     "value": "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 
                        (KHTML, like Gecko) PhantomJS/2.1.1 Safari/538.1"  
                  } 
               ], 
               
               "queryString": [], 
               "headersSize": -1, 
               "bodySize": -1 
            }, 
            "response": { 
               "status": 301, 
               "statusText": "Moved Permanently", 
               "httpVersion": "HTTP/1.1", 
               "cookies": [], 
               
               "headers": [ 
                  { 
                     "name": "Date", 
                     "value": "Sun, 21 May 2017 13:41:25 GMT" 
                  }, 
                  
                  { 
                     "name": "Server", 
                     "value": "Apache/2.2.14 (Ubuntu)" 
                  }, 
                  
                  { 
                     "name": "Location", 
                     "value": "http://sample.com//" 
                  }, 
                  
                  { 
                     "name": "Vary", 
                     "value": "Accept-Encoding" 
                  }, 
                  
                  { 
                     "name": "Content-Encoding", 
                     "value": "gzip" 
                  }, 
                  
                  { 
                     "name": "Keep-Alive", 
                     "value": "timeout = 15, max = 100" 
                  },
                  
                  { 
                     "name": "Connection", 
                     "value": "Keep-Alive" 
                  }, 
                  
                  { 
                     "name": "Content-Type", 
                     "value": "text/html; charset = iso-8859-1" 
                  } 
               ],  
               "redirectURL": "", 
               "headersSize": -1, 
               "bodySize": 307, 
               
               "content": { 
                  "size": 307, 
                  "mimeType": "text/html; charset = iso-8859-1" 
               } 
            }, 
            
            "cache": {}, 
            "timings": { 
               "blocked": 0, 
               "dns": -1, 
               "connect": -1, 
               "send": 0, 
               "wait": 1999, 
               "receive": 0, 
               "ssl": -1 
            }, 
            "pageref": "http://www.sample.com" 
         }, 
      ]   
      { 
         "startedDateTime": "2017-05-21T13:41:24.898Z", 
         "time": 885, 
         
         "request": { 
            "method": "GET", 
            "url": "http://sample.com/", 
            "httpVersion": "HTTP/1.1", 
            "cookies": [], 
            
            "headers": [ 
               { 
                  "name": "Accept", 
                  "value": "text/html,application/xhtml+xml,
                     application/xml;q = 0.9,*/*;q = 0.8" 
               }, 
               
               { 
                  "name": "User-Agent", 
                  "value": "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 
                     (KHTML, like Gecko) PhantomJS/2.1.1 Safari/538.1" 
               } 
            ], 
            "queryString": [], 
            "headersSize": -1, 
            "bodySize": -1 
         }, 
         "response": { 
            "status": 200, 
            "statusText": "OK", 
            "httpVersion": "HTTP/1.1", 
            "cookies": [], 
            
            "headers": [ 
               { 
                  "name": "Date", 
                  "value": "Sun, 21 May 2017 13:41:27 GMT" 
               }, 
               
               { 
                  "name": "Server", 
                  "value": "Apache/2.2.14 (Ubuntu)" 
               }, 
               
               { 
                  "name": "X-Powered-By", 
                  "value": "PHP/5.3.2-1ubuntu4.29" 
               }, 
               
               {
                  "name": "X-Pingback", 
                  "value": "http://sample.com/xmlrpc.php" 
               }, 
               
               { 
                  "name": "Link", 
                  "value": "<http://sample.com/wp-json/>; 
                     rel = \"https://api.w.org/\", <http://wp.me/P6Jj5H-4>; 
                     rel = shortlink" 
               }, 
               
               { 
                  "name": "Vary", 
                  "value": "Accept-Encoding"  
               }, 
               
               { 
                  "name": "Content-Encoding",
                  "value": "gzip" 
               },

               { 
                  "name": "Keep-Alive",
                  "value": "timeout = 15, max = 99"
               },

               {
                  "name": "Connection",
                  "value": "Keep-Alive"
               },

               { 
                  "name": "Content-Type",
                  "value": "text/html; charset = UTF-8"
               }
            ],

            "redirectURL": "",
            "headersSize": -1,
            "bodySize": 1969,

            "content": {
               "size": 1969,
               "mimeType": "text/html; charset = UTF-8"
            }
         },

         "cache": {},
         "timings": {
            "blocked": 0,
            "dns": -1,
            "connect": -1,
            "send": 0,
            "wait": 869,
            "receive": 16,
            "ssl": -1
         },

         "pageref": http://www.sample.com
      },

      {
         "startedDateTime": "2017-05-21T13:41:25.767Z",
         "time": 388,

         "request": {
            "method": "GET",
            "url": "http://sample.com/wpcontent/themes/samplecom/style.css",
            "httpVersion": "HTTP/1.1",
            "cookies": [],

            "headers": [
               {
                  "name": "Accept",
                  "value": "text/css,*/*;q = 0.1"
               },

               {
                  "name": "Referer",
                  "value": "http://sample.com/"
               },

               {
                  "name": "User-Agent",
                  "value": "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 
                     (KHTML, like Gecko) PhantomJS/2.1.1 Safari/538.1"
               }
            ],

            "queryString": [],
            "headersSize": -1,
            "bodySize": -1
         },

         "response": {
            "status": 200,
            "statusText": "OK",
            "httpVersion": "HTTP/1.1",
            "cookies": [],

            "headers": [
               {
                  "name": "Date",
                  "value": "Sun, 21 May 2017 13:41:27 GMT"
               },

               {
                  "name": "Server",
                  "value": "Apache/2.2.14 (Ubuntu)"
               },

               {
                  "name": "Last-Modified",
                  "value": "Fri, 22 Apr 2011 00:32:22 GMT"
               },

               {
                  "name": "ETag",
                  "value": "\"e1d7-1836-4a176fdbbd180\""
               },

               {
                  "name": "Accept-Ranges",
                  "value": "bytes"
               },

               {
                  "name": "Vary",
                  "value": "Accept-Encoding"
               },

               {
                  "name": "Content-Encoding",
                  "value": "gzip"
               },

               {
                  "name": "Keep-Alive",
                  "value": "timeout = 15, max = 98"
               },

               {
                  "name": "Connection",
                  "value": "Keep-Alive"
               },

               {
                  "name": "Content-Type",
                  "value": "text/css"
               }
            ],

            "redirectURL": "",
            "headersSize": -1,
            "bodySize": 3174,
            
            "content": {
               "size": 3174,
               "mimeType": "text/css"
            }
         },

         "cache": {},
         "timings": {
            "blocked": 0,
            "dns": -1,
            "connect": -1,
            "send": 0,
            "wait": 388,
            "receive": 0,
            "ssl": -1
         },
         
         "pageref": "http://www.sample.com"
      }
   }
}

Production

Le programme ci-dessus génère la sortie suivante.

Tous les journaux sont collectés dans un .txt file et plus tard, le même est converti comme ci-dessus en utilisant l'aperçu HAR, par exemple, (http://www.softwareishard.com/har/viewer/)

PhantomJSa beaucoup d'API pour une page Web, qui donne tous les détails. PhantomJS peut être utilisé pour des tests comme obtenir le contenu d'une page, prendre un partage d'écran, convertir une page en pdf, etc. Il existe de nombreuses bibliothèques de tests populaires sur le marché, qui peuvent être utilisées avec PhantomJS et peuvent être utilisées pour des tests .

Certains des frameworks populaires qui peuvent fonctionner avec PhantomJS sont les suivants -

  • Mocha
  • Jasmine
  • Qunit
  • Hiro
  • Laika
  • Buster.JS
  • WebDriver

Exemple - PhantomJS avec Qunit

(function () {     
   var url, timeout,args = require('system').args, page = require('webpage').create(); 
   url = args[1]; 
   timeout = parseInt(10, 10); 
   
   page.onConsoleMessage = function (msg) {  
      //prints all the console messages 
      console.log(msg); 
   }; 
   page.onInitialized = function () {  // called when page is initialized 
      page.evaluate(callqunit); 
   }; 
   page.onCallback = function (message) { // called from  
      var result, failed; 
      
      if (message) {  
         if (message.name === 'QUnit.done') { 
            result = message.data; 
            failed = !result || !result.total || result.failed;  
            
            if (!result.total) { 
               console.error('No tests were executed'); 
            } 
            pageexit(failed ? 1 : 0); 
         } 
      } 
   };  
   page.open(url, function (status) { // opening page  
      if (status !== 'success') { 
         console.error('Unable to access network: ' + status); 
         pageexit(1); 

      } else { 
         var checkqunit = page.evaluate(function () { 
            //evaluating page and chcking if qunit object 
               is present on the given page url 
            return (typeof QUnit === 'undefined' || !QUnit); 
         }); 
         
         if (checkqunit) { 
            console.error('Qunit scripts are not present on the page'); 
            pageexit(1); 
         }             
         
         //timeout of 10seconds is used otherwise message from console will get printed. 
         setTimeout(function () { 
            console.error('The specified timeout of ' + timeout + ' seconds has expired. 
               Aborting...'); 
            pageexit(1); 
         }, timeout * 1000);           
      } 
   });  
   function callqunit() {

qunit.html

<!DOCTYPE html> 
<html> 

   <head> 
      <meta charset = "utf-8"> 
      <meta name = "viewport" content = "width = device-width"> 
      <title>QUnit Example</title> 
      <link rel = "stylesheet" href = "https://code.jquery.com/qunit/qunit-2.3.2.css"> 
   </head> 

   <body> 
      <div id = "qunit"></div> 
      <div id = "qunit-fixture"></div> 
      <script src = "https://code.jquery.com/qunit/qunit-2.3.2.js"></script> 
   </body> 
   
</html>

Production

Command - phantomjs qunit.js http: //localhost/tasks/qunit.html

Le programme ci-dessus génère la sortie suivante.

{"passed":3,"failed":2,"total":5,"runtime":23}
Time taken is 23ms to run 5 tests.
3 passed, 2 failed.

REPL signifie Read Eval Print Loop. Dans PhantomJS, REPL est un mode interactif pour tester le code JavaScript. Vous pouvez faire la même chose, qui se fait dans Google Chrome Inspector ou Firebug pour exécuter un morceau de code directement sur la console. REPL vous renvoie la même plateforme pour exécuter les scripts.

La commande tapée est envoyée à l'interpréteur pour interprétation immédiate (EVAL) et pour fournir un retour (PRINT). EntrerPhantomJS dans la ligne de commande et il vous mènera au mode interactif, où vous pouvez exécuter votre code directement.

Syntaxe

Sa syntaxe est la suivante -

Phantomjs

Exemple

L'exemple suivant montre comment REPL fonctionne dans PhantomJS.

phantomjs> console.log("Welcome to phantomjs");
Welcome to phantomjs
Undefined

phantomjs> window.navigator {
   "appCodeName": "Mozilla",
   "appName": "Netscape",
   "appVersion": "5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 (KHTML, like Gecko)
      PhantomJS/2.1.1 Safari/538.1",
   "cookieEnabled": true,
   "language": "en-IN",

   "mimeTypes": {
      "length": 0
   },
   "onLine": false,
   "platform": "Win32",

   "plugins": {
      "length": 0
   },
   "product": "Gecko
   "productSub": "20030107",
   "userAgent": "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/538.1 (KHTML, like Gecko)
      PhantomJS/2.1.1 Safari/538.1",
   "vendor": "Apple Computer, Inc.",
   "vendorSub": ""
}

phantomjs>
To find the version
phantomjs> phantom.version {
   "major": 2,
   "minor": 1,
   "patch": 1
}
phantomjs>

Chaque commande est exécutée et le résultat est affiché. Utilisez CTRL + C, CTRL + D ouphantom.exit() pour sortir du mode interactif.

Utilisez le up/down les touches fléchées pour écouter les commandes saisies précédemment.

Il existe une autre fonctionnalité appelée autocompletion, ce qui aide à se souvenir de la commande. Tapez simplement "fantôme" et appuyez sur le bouton "Tab" pour obtenir une liste des commandes disponibles que vous pouvez exécuter.

Production

Le programme ci-dessus génère la sortie suivante.

phantomjs> phantom.→| 
phantomjs> phantom.cookies→| 
phantomjs> phantom.exit→| 
phantomjs> phantom.version→|

Dans ce chapitre, nous fournissons quelques exemples pratiques supplémentaires pour comprendre certaines fonctionnalités importantes de PhantomJS.

Exemple 1 - Trouver la vitesse de la page

Dans cet exemple, nous utiliserons PhantomJS pour trouver le page speed pour toute URL de page donnée.

var page = require('webpage').create(), 
   system = require('system'), 
   t, address;  

if (system.args.length === 1) { 
   console.log('Usage: loadspeed.js <some URL>'); 
   phantom.exit(1); 
} else { 
   t = Date.now(); 
   address = system.args[1]; 
   
   page.open(address, function (status) { 
      if (status !== 'success') { 
         console.log('FAIL to load the address'); 
      } else { 
         t = Date.now() - t; 
         
         console.log('Page title is ' + page.evaluate(function () { 
            return document.title; 
         })); 
         console.log('Loading time ' + t + ' msec'); 
      } 
      phantom.exit(); 
   }); 
}

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

Command - phantomjs pagespeed.js http://www.google.com

Page title is Google 
Loading time 1396 msec

Exemple 2 - Envoyer un événement de clic vers une page

Dans l'exemple suivant, nous utiliserons PhantomJS pour envoyer un click event à une page.

var page = require('webpage').create(); 
page.onConsoleMessage = function(str) { 
   console.log(str); 
} 
page.open('http://phantomjs.org/api/phantom/', function(status) { 
   page.render('beforeclick.png'); 
   console.log(page.url); 
   
   var element = page.evaluate(function() {   
      return document.querySelector('img[src = "http://phantomjs.org/img/phantomjslogo.png"]'); 
   }); 
   page.sendEvent('click', element.offsetLeft, element.offsetTop, 'left'); 
   
   window.setTimeout(function () { 
      console.log(page.url); 
      page.render('afterclick.png'); 
      phantom.exit(); 
   }, 5000); 
   console.log('element is ' + element); 
});

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

http://phantomjs.org/api/phantom/ 
element is [object Object] 
http://phantomjs.org/

Notre programme créera les deux suivants png images dans le bindossier. Ces deux images montrent la différence avant et après l'exécution du programme ci-dessus.

Exemple 3 - Soumettre un formulaire

L'exemple suivant montre comment soumettre un formulaire à l'aide de PhantomJS.

var wpage = require('webpage').create();  
wpage.open("http://localhost/tasks/submitform.html", function(status) { 
   console.log(status); 
   wpage.uploadFile('input[name = fileToUpload]', 'output.png'); 
   wpage.render("sform.png");  
   
   var element = wpage.evaluate(function() {   
      return document.querySelector('input[type = "submit"]');   
      // getting details of submit button using queryselector. 
   }); 
   wpage.sendEvent('click', element.offsetLeft, element.offsetTop, 'left');  
   
   // sendevent is used to send click event and also giving the left and top 
      position of the submit button. 
   
   window.setTimeout(function () { 
      console.log(wpage.url); 
      wpage.render("submit.png");  // screenshot is saved in submit.png 
      phantom.exit(); 
   }, 5000);  
   console.log('element is ' + element);  
});

submitform.html

Le code suivant montre comment utiliser le submitform.html fichier.

<html> 
   <head>
      <title>Window 2</title>
   </head> 

   <body>
      <form action = "submitform.php" method = "post" enctype = "multipart/form-data" 
         id = "form1">  
         <input type = "file" name = "fileToUpload" id = "fileToUpload"> 
         <input type = "submit" value = "Upload Image" name = "submit"> 
      </form> 
   </body>  
   
</html>

Une fois le formulaire soumis, il va à submitform.php.

submitform.php

submitform.php imprime simplement les détails des fichiers.

<?php 
   print_r($_FILES); 
?>

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

Success 
element is [object Object] 
http://localhost/tasks/submitform.php

Images

Voici les images pour file upload et form submit.