Introducción a JAXB con NetBeans
Hay muchas técnicas de manipular ficheros XML en el mundo Java,
como tratamos
en tutoriales anteriores, y vamos a ver una muy buena opción con JAXB
(Java Architecture for XML Binding )
Antes de hacer un ejemplo con esta tecnología, vamos a montar el Kit de
desarrollo de Web Services, donde viene incluido (utilizaremos este tutorial
como base para otros relacionados con Web Services)
No olvidéis que la primera fuente a consultar siempre, es la original, el
tutorial de Sun.
http://java.sun.com/webservices/docs/1.6/tutorial/doc/index.html
Y que en www.programacion.net se
currar mucho las traducciones (os recomiendo que lo añadáis a vuestras lista de
RSS)
http://www.programacion.com/java/tutorial/jaxb/1
Descarga de WSDP
Lo descargamos del Web de Sun
Y arrancamos el ejecutable
Nos aparece el asistente
Elegimos la máquina virtual (un consejo, evitad los espacios en los trayectos
de instalación)
Elegimos la opción de utilizar un Tomcat como contenedor para nuestra
aplicaciones y servicios Web
Nos descargamos el Tomcat para WSDP
Lo descomprimimos un directorio
Ahora seleccionamos el producto recién instalado
Elegimos el directorio del resto de componentes
Realizamos la instalación típica
Aunque os muestro las opciones en la personalizada….. que ya tenemos
tema para un montón de tutoriales sobre las últimas especificaciones
relacionadas con los servicios web (sobre todo debemos estar atentos a la
evolución de la seguridad)
Definimos el usuario que usuremos para manejar remotamente el Tomcat
No olvidéis que este usuario hay que darlo de alta en el TOMCAT
<!– NOTE: By default, no user is included in the «manager» role required to operate the «/manager» web application. If you wish to use this app, you must define such a user – the username and password are arbitrary. –> <tomcat-users> <user name=»tomcat» password=»tomcat» roles=»tomcat» /> <user name=»role1″ password=»tomcat» roles=»role1″ /> <user name=»both» password=»tomcat» roles=»tomcat,role1″ /> <user name=»admin» password=»admin» roles=»manager,admin» /> </tomcat-users> |
No se os olvide leer las instrucciones finales (lo digo porque al final
hacemos ok, ok, ok y no nos funcionan las cosas)
Copiamos los jar al directorio propuesto
Y ahora acabamos
Y al arrancar sobre los iconos creados ….. no podría dar este
pequeño error… solo tenemos que ir al directorio de binarios de tomcat y
localizar el fichero catalina.bat (actualizando así el acceso directo)
Primer ejemplo de JAXB
Creamos un proyecto dentro de NetBeans 4.1. Será una aplicación Web básica
Elegimos el nombre y trayecto
La gracia está en que a partir de un Schema (esquema) XML podemos crear una
estructura de clases que nos permitan un acceso cómodo y seguro (verificación de
que hacemos lo que debemos en compilación y no en ejecución)
Creamos el esquema
Le damos un nombre (libros.xsd)
<?xml version=»1.0″ encoding=»ISO-8859-1″?>
<xsd:schema xmlns:xsd=»http://www.w3.org/2001/XMLSchema» <xsd:element name=»libro»> <xsd:element name=»libros» > </xsd:schema> |
Creamos un fichero XML que use ese esquema
Decimos que se valide contra un esquema
Y le damos los detalles (el fichero lo llamamos libros.xml)
<?xml version=»1.0″ encoding=»ISO-8859-1″?>
<libros xmlns=’http://www.adictosaltrabajo.com/esquemas/libro’
|
Bueno, hasta ahora no hemos realizado nada raro …. vamos
con la parte específica
Invocamos fichero xjc.bat pasando como parámetro el
trayecto del fichero xml. También podemos especificar el directorio donde se
generarán las clases
xjc.bat -d directoriofinal ficheros.xsd
Ahora, en nuestro proyecto le vamos a incorporar los JAR de JAXB
Las elegimos
Y pinchando sobre las propiedades del proyecto, añadimos el trayecto de los
ficheros generados automáticamente.
Vemos es aspecto de nuestro proyecto
Y ya solo nos queda escribir el código específico.
package adictosjaxb; import com.adictosaltrabajo.esquemas.libro.*; import com.adictosaltrabajo.esquemas.libro.impl.*; import javax.xml.bind.*; import java.io.*; import java.util.*; /** * * @author Roberto Canales */ public class Main { public static void depura(String cadena) { System.out.println("adictosjaxb: " + cadena); } public static void main(String[] args) { depura("Empezamos la operación"); try { JAXBContext jc = JAXBContext.newInstance( "com.adictosaltrabajo.esquemas.libro" ); Unmarshaller u = jc.createUnmarshaller(); // es una chapuza pero para el ejemplo nos vale InputStream in = new FileInputStream("c:/xml/libros.xml"); if(in == null) { depura("No encuentro el fichero"); return; } // construimos el modelo a partir el stream de entrada Libros mifichero = (Libros)u.unmarshal( in ); // recuperamos la lista de libros List mislibros = mifichero.getLibro(); int numero = mislibros.size(); depura("El numero de libros es " +numero ); for (int i = 0; i // ahora añadimos un libro nuevo LibroTypeImpl nuevoLibro = new LibroTypeImpl(); // establecemos los elementos nuevoLibro.setTitulo("Domina tu proyecto"); nuevoLibro.setAutor("Anónimo"); // añadimos a la lista mislibros.add(nuevoLibro); // vamos a pintar ahora el arbol XML generado para asegurarnos que se ha añadido Marshaller formateador = jc.createMarshaller(); formateador.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE); formateador.marshal( mifichero, System.out ); // ahora escribimos a un fichero, en el correcto juego de caracteres formateador.setProperty(Marshaller.JAXB_ENCODING, "ISO-8859-1"); FileOutputStream salida = new FileOutputStream("c:/xml/salida.xml"); formateador.marshal( mifichero, salida); } catch(Exception e) // esto es otra chapucilla, no me copieis { depura("el error es " + e.toString()); } } } |
Analizamos el código
Si lo analizamos, veremos que con 4 líneas, hacemos operaciones comunes…
Recuperar el contenido de un fichero:
JAXBContext jc = JAXBContext.newInstance( "com.adictosaltrabajo.esquemas.libro" ); Unmarshaller u = jc.createUnmarshaller(); // es una chapuza pero para el ejemplo nos vale InputStream in = new FileInputStream("c:/xml/libros.xml"); if(in == null) { depura("No encuentro el fichero"); return; } // construimos el modelo a partir el stream de entrada Libros mifichero = (Libros)u.unmarshal( in ); // recuperamos la lista de libros List mislibros = mifichero.getLibro(); int numero = mislibros.size(); depura("El numero de libros es " +numero ); for (int i = 0; i |
Insertar un nuevo nodo
// ahora añadimos un libro nuevo LibroTypeImpl nuevoLibro = new LibroTypeImpl(); // establecemos los elementos nuevoLibro.setTitulo("Domina tu proyecto"); nuevoLibro.setAutor("Anónimo"); // añadimos a la lista mislibros.add(nuevoLibro); |
Volcar el contenido a la pantalla
// vamos a pintar ahora el arbol XML generado para asegurarnos que se ha añadido Marshaller formateador = jc.createMarshaller(); formateador.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE); formateador.marshal( mifichero, System.out ); |
Y escribir el contenido en un fichero
// ahora escribimos a un fichero, en el correcto juego de caracteres formateador.setProperty(Marshaller.JAXB_ENCODING, "ISO-8859-1"); FileOutputStream salida = new FileOutputStream("c:/xml/salida.xml"); formateador.marshal( mifichero, salida); |
Conclusiones
La opción de JAXB, junto con JDOM, es una de mis preferidas para manipular de un
modo rápido y sencillo ficheros XML.
De todos modos podemos sacar algunas conclusiones importantes:
- Cada vez hay más técnicas para hacer lo mismo.
- Los conocimientos (aparentemente) cada vez tienen un ciclo de vida más
corto - No es tan importante el manipular el fichero XML como definir bien su
esquema desde un principio (lo que requiere saber analizar).