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 ce que sont les 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.
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 :
·Analyseur arborescent : cet analyseur convertit le document XML en une structure arborescente. Il analyse l'intégralité du document et fournit des API pour accéder aux éléments de l'arborescence, tels que le Document Object Model (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, et non sur leurs résultats. Pour cette raison, les analyseurs basés sur des événements peuvent accéder aux données plus rapidement que les analyseurs basés sur des arborescences.
Regardez le fragment XML suivant :
<from>John</from>
L'analyseur basé sur les événements rapporte le XML ci-dessus comme une séquence de trois événements :
· Démarrage élément : from
·Démarrage de la section CDATA, valeur : John
·Élément de clôture : from
Le XML ci-dessus Le les exemples contiennent du XML bien formé. Cependant, cet exemple n'est pas du XML valide, car aucune déclaration de type de document (DTD) n'y est associée et aucune DTD n'est intégrée.
Recommandations associées : "Tutoriel d'introduction à php"
Cependant, il n'y a 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.
Installer
L'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 :
George <from>John</from>Reminder Don't forget the meeting!
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 ce fichier XML.
Exemple :
<?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); ?>
Sortie du code ci-dessus :
-- Note -- To: George From: John Heading: Reminder Message: Don't forget the meeting!
Explication du principe de fonctionnement :
·Initialisé via xml_parser_create () fonction analyseur XML
·Créer des fonctions pour correspondre à différents gestionnaires d'événements
·Ajouter la fonction xml_set_element_handler() pour définir le moment où l'analyseur rencontre Quelle fonction est exécutée lorsque les balises de début et de fin sont atteintes
·Ajoutez la fonction xml_set_character_data_handler() pour définir quelle fonction est exécutée lorsque l'analyseur rencontre des données de caractères
·Analyser le fichier "test.xml" via la fonction xml_parse()
·En cas d'erreur, ajoutez la fonction xml_error_string() pour convertir le XML erreur dans une description textuelle
·Appelez la fonction xml_parser_free() pour libérer la mémoire allouée à la fonction xml_parser_create()
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!