XML-DOM
PHP XML DOM
L'analyseur DOM intégré permet de traiter des documents XML en PHP.
Qu'est-ce que le DOM ?
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 - pour tout document structuré Définit un standard ensemble d'objets
* XML DOM - Définit un ensemble standard d'objets pour les documents XML
* HTML DOM - Définit un ensemble standard d'objets pour les documents HTML
Pour en savoir plus sur les connaissances XML DOM, visitez notre tutoriel XML DOM.
Analyse XML
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 un document 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 le temps : traite un document XML comme une séquence 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 texte : "Jani"
Installer
Fonction d'analyseur XML DOM C'est un 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>
< ; head>Rappel</heading>
<body>Ne m'oubliez pas ce week-end !</body>
</note>
Chargement et sortie XML
Nous devons initialiser l'analyseur XML, charger le XML et le sortir :
Exemple
<?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>Reminder</heading> <body>Don't forget me this weekend!</body> </note>
L'exemple ci-dessus crée un objet DOMDocument 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.
Traversing XML
Nous souhaitons initialiser l'analyseur XML, charger le XML et parcourir tous les éléments de l'élément <note> :
Instance
<?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 =
de = Jani
#text =
heading = Rappel
#text =
body = Ne m'oubliez pas ce week-end !
#text =
ci-dessus Dans le cas de , vous voyez des nœuds de texte vides entre chaque élément.
Lorsque XML est généré, il contient souvent 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 tutoriel XML DOM.