Table des matières:
- Code polyvalent par rapport au code personnalisé
- Les avantages de la personnalisation
- L'essence de JAXB
Vidéo: Ajouter, Supprimer, Rechercher et Modifier les données d'une BDD MySql en JAVA 2024
Vous pouvez créer du code personnalisé avec JAXB - le API Java pour la liaison XML . Avec JAXB, vous prenez un document XML et vous créez un fichier de classe Java parfait pour le traitement du document. Lorsque vos besoins changent et que la classe ne fait plus ce que vous voulez, vous créez une nouvelle sous-classe.
Lorsque vous écrivez du code SAX ou DOM, vous créez un programme de traitement XML. Votre programme lit un document et utilise le document pour effectuer un travail utile, en commençant par quelque chose d'inoffensif comme public void startElement ou node. getNodeName (). De toute façon, votre programme ne fait aucune supposition sur ce qu'il y a dans le document. Le document a un élément racine, des éléments enfants, et c'est tout. Toutes les hypothèses spéciales que vous faites sur ce document réduisent l'utilité du code.
Code polyvalent par rapport au code personnalisé
Considérez le code dans les listes 1 et 2. La liste 1, analyse cinq nœuds dans une arborescence de documents. Ces cinq nœuds doivent être arrangés d'une certaine façon, sinon le programme plante. (La liste veut un commentaire et un nœud racine, avec au moins deux enfants directement sous le nœud racine.)
Listing 1: Afficher quelques nœuds
import org. W3C. dom. Nœud;
import org. W3C. dom. NamedNodeMap;
classe MyTreeTraverser
{
MyTreeTraverser (Nœud de nœud)
{
Système. en dehors. println (noeud getNodeName ());
noeud = noeud. getFirstChild ();
Système. en dehors. println (noeud getNodeName ());
noeud = noeud. getNextSibling ();
Système. en dehors. println (noeud getNodeName ());
noeud = noeud. getFirstChild ();
Système. en dehors. println (noeud getNodeName ());
noeud = noeud. getNextSibling ();
Système. en dehors. println (noeud getNodeName ());
}
}
Listing 2: Traverser l'arborescence DOM
import org. W3C. dom. Nœud;
import org. W3C. dom. NamedNodeMap;
classe MyTreeTraverser
{
Nœud de noeud;
MyTreeTraverser (Noeud de noeud)
{
this. noeud = noeud;
displayName ();
displayValue ();
if (noeud.getNodeType () == Noeud. ELEMENT_NODE)
displayAttributes ();
Système. en dehors. println ();
displayChildren ();
}
void displayName ()
{
Système. en dehors. print ("Nom:");
Système. en dehors. println (noeud getNodeName ());
}
void displayValue ()
{
Chaîne nodeValue = noeud. getNodeValue ();
if (nodeValue! = Null)
nodeValue = valeur_noeud. réduire();
Système. en dehors. print ("Valeur:");
Système. en dehors. println (nodeValue);
}
void displayAttributes ()
{
NamedNodeMap attribs = noeud. getAttributes ();
pour (int i = 0; i { Système. en dehors. println (); Système. en dehors. print ("Attribut:"); Système. en dehors. print (attributs: item (i). getNodeName ()); Système. en dehors. print ("="); Système. en dehors. println (attributs: item (i).getNodeValue ()); } } void displayChildren () { Noeud enfant = noeud. getFirstChild (); while (enfant! = Null) { nouveau MyTreeTraverser (enfant); enfant = enfant. getNextSibling (); } } } Le code du Listing 2 est beaucoup plus général. Ce code vérifie la structure du document lors de son exécution. Lorsque le code trouve un nœud enfant, il analyse l'enfant et recherche les petits-enfants. S'il n'y a pas de petits-enfants, le code recherche les frères et sœurs. Le code peut gérer n'importe quel arbre de document - qu'il ait un nœud ou un millier de nœuds. Ainsi, la liste 2 est plus polyvalente que la liste 1. Cependant, cette polyvalence présente des inconvénients - y compris la possibilité de frais généraux très élevés. Le code dans la liste 2 doit analyser le document XML entier - et ensuite mettre une représentation de l'arbre du document dans la mémoire de l'ordinateur. Si le document est très volumineux, la représentation est grande: la mémoire est gonflée avec toutes ces données temporaires et le code du listing 2 ralentit jusqu'à une analyse. Imaginez que vous essayez de vous rendre à Faneuil Hall à Boston, Massachusetts. Peu importe d'où vous venez; le voyage sera toujours confus et difficile. Quoi qu'il en soit, vous devez planifier votre itinéraire. Vous pouvez vous perdre dans les environs de Revere ou Cambridge ou dans le centre de Boston. Selon vos ressources, vous avez deux options: L'utilisation de la carte papier demande plus de travail (plus de temps, d'effort, de dextérité et de patience) que l'utilisation du GPS parlant. Pourquoi? Parce que la carte papier n'est pas adaptée à vos besoins spécifiques; En effet, il dit: «Voici toute la région métropolitaine de Boston. Faneuil Hall est là quelque part. Vous décidez quoi faire ensuite. " Un système personnalisé est (comme vous pouvez vous y attendre) plus facile à utiliser qu'un autre qui n'est pas adapté à votre situation immédiate. Ainsi, le code de traitement XML du Listing 2 fait un énorme arbre DOM déglutissant les ressources dans l'espace mémoire de votre ordinateur ("Voici l'arbre - vous devinez quoi faire ensuite …") parce que le code n'est pas t personnalisé.Le code fonctionne pour n'importe quel document ancien - pas seulement celui que vous avez en main - et avale toujours des ressources pour le faire. L'idée derrière JAXB est de créer des cours personnalisés pour répondre à vos besoins actuels. Vous prenez la description d'un document XML, exécutez-le via un programme spécial appelé compilateur de schéma , et obtenez une toute nouvelle classe appelée la classe générée . Cette classe générée est rationalisée pour fonctionner avec des documents XML particuliers. Par exemple, si vos documents XML ont des éléments nommés Total, la classe générée peut avoir des méthodes setTotal et getTotal. Si l'élément d'un document a un attribut fullName, la classe générée peut avoir des méthodes setFullName et getFullName. (Voir Figure 1.) La connexion entre une partie d'un document XML et une partie d'une classe Java est appelée liaison . Avec toutes ces liaisons, une instance de la classe représente un seul document XML. Alors comment connecter un objet avec un document XML? Eh bien, la classe générée a des méthodes nommées unmarshal et marshal. (Voir la figure 2.) Avec des méthodes comme celles-ci, vous pouvez récupérer et modifier les données dans un document XML.Les avantages de la personnalisation
L'essence de JAXB