Analyseur PHP XML Expat

Analyseur PHP XML Expat


L'analyseur Expat intégré permet de traiter des documents XML en PHP.


Qu'est-ce que XML ?

XML est utilisé pour décrire les données, l'accent étant mis sur la nature des données. Les fichiers XML décrivent la structure des données.

En XML, il n'y a pas de balises prédéfinies. Vous devez définir vos propres balises.

Pour en savoir plus sur XML, visitez notre tutoriel XML.


Qu'est-ce qu'Expat ?

Pour lire et mettre à jour - créer et traiter - un document XML, vous avez besoin d'un analyseur XML.

Il existe deux types de base d'analyseurs XML :

· Analyseurs arborescents : cet analyseur convertit les documents XML en une structure arborescente. Il analyse l'intégralité du document et donne accès aux éléments de l'arborescence, tels que le modèle objet de document (DOM).

· Analyseur basé sur les événements : traitez les documents XML comme une série d'événements. Lorsqu'un événement spécifique se produit, l'analyseur appelle une fonction pour le gérer.

L'analyseur Expat est un analyseur basé sur des événements.

Les analyseurs basés sur les événements se concentrent sur le contenu des documents XML plutôt que sur leur structure. Pour cette raison, les analyseurs basés sur des événements sont capables d'accéder aux données plus rapidement que les analyseurs basés sur des arborescences.

Regardez le fragment XML suivant :

<from>Jani</from>

L'analyseur basé sur les événements rapporte le XML ci-dessus sous la forme d'une série de trois événements :

· Élément de départ : from

· Section CDATA de départ, valeur : Jani

· Élément de clôture : from

L'exemple XML ci-dessus contient le formulaire Good XML. Toutefois, cette instance n'est pas du XML valide, car aucune déclaration de type de document (DTD) ne lui est associée.

Cependant, cela ne fait aucune différence lors de l'utilisation de l'analyseur Expat. Expat est un analyseur qui ne vérifie pas la validité et ignore toute DTD.

En tant qu'analyseur XML non validé basé sur des événements, Expat est rapide et léger, ce qui le rend idéal pour les applications Web PHP.

Remarque : Le document XML doit être bien formé, sinon Expat générera une erreur.


Installation

La fonction d'analyseur XML Expat fait partie intégrante du noyau PHP. Aucune installation n'est requise pour utiliser ces fonctions.


Fichier XML

Le fichier XML suivant sera utilisé dans notre exemple :

<?xml version="1.0" encoding="ISO-8859-1"?>
 <note>
 <to>Tove</to>
 <from>Jani</from>
 <heading>Reminder</heading>
 <body>Don't forget me this weekend!</body>
 </note>


Initialisation de l'analyseur XML

Nous allons initialiser l'analyseur XML en PHP, définir des gestionnaires pour différents événements XML, puis analyser le fichier XML.

Instance

<?php
 //Initialize the XML parser
 $parser=xml_parser_create();
 
 //Function to use at the start of an element
 function start($parser,$element_name,$element_attrs)
 {
 switch($element_name)
 {
 case "NOTE":
 echo "-- Note --<br>";
 break;
 case "TO":
 echo "To: ";
 break;
 case "FROM":
 echo "From: ";
 break;
 case "HEADING":
 echo "Heading: ";
 break;
 case "BODY":
 echo "Message: ";
 }
 }
 
 //Function to use at the end of an element
 function stop($parser,$element_name)
 {
 echo "<br>";
 }
 
 //Function to use when finding character data
 function char($parser,$data)
 {
 echo $data;
 }
 
 //Specify element handler
 xml_set_element_handler($parser,"start","stop");
 
 //Specify data handler
 xml_set_character_data_handler($parser,"char");
 
 //Open XML file
 $fp=fopen("test.xml","r");
 
 //Read data
 while ($data=fread($fp,4096))
 {
 xml_parse($parser,$data,feof($fp)) or 
 die (sprintf("XML Error: %s at line %d", 
 xml_error_string(xml_get_error_code($parser)),
 xml_get_current_line_number($parser)));
 }
 
 //Free the XML parser
 xml_parser_free($parser);
 ?>

Le code ci-dessus affichera :

-- Remarque --
À : Tove
De : Jani
Titre : Rappel
Message : Ne m'oubliez pas ce week-end !

Principe de fonctionnement :

1. Initialisez l'analyseur XML via la fonction xml_parser_create()

2. Créez un gestionnaire d'événements qui correspond. différents gestionnaires d'événements La fonction

3.                       Ajout de la fonction xml_set_element_handler () pour définir quelle fonction est exécutée lorsque l'analyseur rencontre les balises de début et de fin                                                          Utiliser avec utiliser utiliser utiliser utiliser                                               à Quelle fonction est exécutée lorsque des données de caractères sont rencontrées

5. Utilisez la fonction xml_parse() pour analyser le fichier "test.xml"

6. En cas d'erreur, ajoutez la fonction xml_error_string() pour analyser les erreurs XML. dans les descriptions textuelles

7. Appelez la fonction xml_parser_free() pour libérer la mémoire allouée à la fonction xml_parser_create()

Introduction à PHP XML Parser Les fonctions XML permettent d'analyser des documents XML mais pas de les valider.

XML est un format de données utilisé pour l'échange de documents structurés standards. Vous pouvez trouver plus d'informations sur XML dans notre php.cn.

Cette extension utilise l'analyseur XML Expat.

Expat est un analyseur basé sur des événements qui traite les documents XML comme une série d'événements. Lorsqu'un événement se produit, il appelle une fonction spécifiée pour le gérer.

Expat est un analyseur sans validation qui ignore toute DTD liée au document. Cependant, si le document n’est pas en bon état, il se retrouvera avec un message d’erreur.

Parce qu'il s'agit d'un analyseur basé sur des événements et sans validation, Expat est rapide et adapté aux applications Web.

La fonction d'analyseur XML vous permet de créer un analyseur XML et de définir des gestionnaires pour les événements XML.


Installation

La fonction XML Parser fait partie intégrante du noyau PHP. Aucune installation n'est requise pour utiliser ces fonctions.

Fonction PHP XML Parser

PHP : Indique la première version de PHP prenant en charge cette fonction.


QQ截图20161009165838.pngConstantes de l'analyseur XML PHP

QQ截图20161009165856.png

QQ截图20161009165909.png

Formation continue
||
<?php //Initialize the XML parser $parser=xml_parser_create(); //Function to use at the start of an element function start($parser,$element_name,$element_attrs) { switch($element_name) { case "NOTE": echo "-- Note --<br>"; break; case "TO": echo "To: "; break; case "FROM": echo "From: "; break; case "HEADING": echo "Heading: "; break; case "BODY": echo "Message: "; } } //Function to use at the end of an element function stop($parser,$element_name) { echo "<br>"; } //Function to use when finding character data function char($parser,$data) { echo $data; } //Specify element handler xml_set_element_handler($parser,"start","stop"); //Specify data handler xml_set_character_data_handler($parser,"char"); //Open XML file $fp=fopen("test.xml","r"); //Read data while ($data=fread($fp,4096)) { xml_parse($parser,$data,feof($fp)) or die (sprintf("XML Error: %s at line %d", xml_error_string(xml_get_error_code($parser)), xml_get_current_line_number($parser))); } //Free the XML parser xml_parser_free($parser); ?>
soumettreRéinitialiser le code
  • Recommandations de cours
  • Téléchargement du didacticiel