Diferencia entre revisiones de «Validaciones de XML contra XSD En Java»

De Dos Ideas.
Saltar a: navegación, buscar
(Página creada con 'Necesidad: validar que un XML está formado de acuerdo a las reglas de un XSD. Solución: Para validar un xml, podemos aplicar lo siguiente: import javax.xml.XMLConstants; …')
 
Línea 40: Línea 40:
  
 
Este método constructor de XmlObject acepta varias formas de pasarle el xml a parsear. Es cuestión de buscar la manera que más se adapte a como nosotros recibimos el xml (por un String, archivo, url, etc).
 
Este método constructor de XmlObject acepta varias formas de pasarle el xml a parsear. Es cuestión de buscar la manera que más se adapte a como nosotros recibimos el xml (por un String, archivo, url, etc).
 +
 +
Finalmente, al invocar '''validator.validate(source);''' obtendremos la validación del documento. Si no conformara alguna de las condiciones del XSD, arrojará la excepción '''SAXException''', y si no se logra encontrar el xsd, arroja '''IOException'''.

Revisión del 12:17 5 dic 2012

Necesidad: validar que un XML está formado de acuerdo a las reglas de un XSD.

Solución: Para validar un xml, podemos aplicar lo siguiente:


import javax.xml.XMLConstants;
import javax.xml.transform.Source;
import javax.xml.transform.stream.StreamSource;
import javax.xml.validation.Schema;
import javax.xml.validation.SchemaFactory;
import javax.xml.validation.Validator;
import java.io.IOException;
import java.net.URL;

import org.apache.xmlbeans.XmlObject;
import org.xml.sax.SAXException;

public class ValidadorXml {
   /**
    * Para crear un Schema a partir de un XSD.
    */
   private static SchemaFactory schemaFactory;
   static {
       schemaFactory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
   }
   public static void validarXml(String pathXsd, XmlObject xml) throws IOException, SAXException {
       Schema schema = schemaFactory.newSchema(new URL(pathXsd));
       Validator validator = schema.newValidator();
       Source source = new StreamSource(xml.newInputStream());
       validator.validate(source);
   }
}


En el código anterior utilizamos la clase XmlObject. Podemos obtener una instancia de dicho elemento utilizando:

String mensaje = "<hola></hola>" //cadena que representa el contenido xml.
XmlObject.Factory.parse(mensaje);

Este método constructor de XmlObject acepta varias formas de pasarle el xml a parsear. Es cuestión de buscar la manera que más se adapte a como nosotros recibimos el xml (por un String, archivo, url, etc).

Finalmente, al invocar validator.validate(source); obtendremos la validación del documento. Si no conformara alguna de las condiciones del XSD, arrojará la excepción SAXException, y si no se logra encontrar el xsd, arroja IOException.