L'analyseur DOM intégré permet de traiter des documents XML en PHP.
W3C DOM fournit un ensemble standard d'objets pour les documents HTML et XML, ainsi qu'une interface standard pour accéder et manipuler ces documents. Le DOM du W3C est divisé en différentes parties (Core, XML et HTML) et différents niveaux (DOM niveau 1/2/3) : * Core DOM - définit un ensemble standard d'objets pour tout document structuré * XML DOM - pour les documents XML Définir un ensemble standard d'objets* HTML DOM - Définition d'un ensemble standard d'objets pour les documents HTML Pour en savoir plus sur le XML DOM, visitez notre didacticiel XML DOM.
Pour lire et mettre à jour – créer et traiter – un document XML, vous avez besoin d'un analyseur XML.
Il existe deux types fondamentaux d'analyseurs XML :
Analyseur arborescent : 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 : traite un document 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 DOM est un analyseur arborescent.
Veuillez consulter le fragment de document XML suivant :
<?xml version="1.0" encoding="ISO-8859-1"?><from>Jani</from>
XML DOM traite le XML ci-dessus comme une structure arborescente :
Niveau 1 : document XML
Niveau 2 : élément racine : <from>
Niveau 3 : élément de texte : "Jani"
La fonction d'analyseur XML DOM fait partie intégrante du noyau PHP. Aucune installation n'est requise pour utiliser ces fonctions.
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>Rappel</heading><body>Don ne m'oublie pas ce week-end !</body></note>
Nous devons initialiser l'analyseur XML, charger le XML et le générer :
<?php$xmlDoc = new DOMDocument();$xmlDoc->load("note.xml");print $xmlDoc->saveXML();?>
Le code ci-dessus affichera :
ToveJaniReminder Ne m'oubliez pas ce week-end !
Si vous affichez le code source dans une fenêtre de navigateur, vous verrez le code HTML suivant :
<?xml version="1.0" encoding="ISO-8859-1"?><note><to>Tove</to><from>Jani</from><heading>Rappel</heading><body>Don ne m'oublie pas ce week-end !</body></note>
L'exemple ci-dessus crée un DOMDocument-Object et charge le XML dans "note.xml" dans cet objet document.
La fonction saveXML() place le document XML interne dans une chaîne afin que nous puissions le sortir.
Nous voulons initialiser l'analyseur XML, charger le XML et parcourir tous les éléments de l'élément <note> :
<?php$xmlDoc = new DOMDocument();$xmlDoc->load("note.xml");$x = $xmlDoc->documentElement;foreach ($x->childNodes AS $item) { print $item-> nodeName . " = " . $item->nodeValue "<br>" ;
Le code ci-dessus affichera :
#text = to = Tove#text = from = Jani#text = head = Rappel#text = body = Ne m'oubliez pas ce week-end !#text =
Dans l'exemple ci-dessus, vous voyez qu'il y a des nœuds de texte vides entre chaque élément.
Lorsque XML est généré, il contient généralement des espaces entre les nœuds. L'analyseur XML DOM les traite comme des éléments normaux, ce qui peut parfois poser des problèmes si vous n'y prêtez pas attention.
Pour en savoir plus sur XML DOM, visitez notre didacticiel XML DOM.