[英]Is there any best way to validate generated XML against XSD in Java
我正在使用Javax Marshaller生成xml。 我正在尋找驗證生成的XML反對XSD的方法。 我發現gradle插件可以做到這一點。 但是我不能使用這個插件,因為它給了一些錯誤
Could not resolve gradle.plugin.com.github.ramonwirsch:fopRenderer:0.1.7
我的build.gradle文件:
buildscript {
repositories {
jcenter()
maven {
url "https://plugins.gradle.org/m2/"
}
}
dependencies {
classpath "gradle.plugin.com.github.ramonwirsch:fopRenderer:0.1.7"
}
}
apply plugin: "com.github.ramonwirsch.FopRenderer"
apply plugin: 'java'
apply plugin: 'eclipse'
sourceCompatibility=1.8
targetCompatibility=1.8
project.ext {
app_name='XSD-XML'
build_date=new Date().format("yyyyMMddHHmm")
release_number='R1.0'
rc_build="${System.env.BUILD_NUMBER}"//look for BUILD_NUMBER in env (set by Jenkins)
generatedSrcDir = file("$buildDir/generated-src")
jaxb_schema='src/main/resources/xsd'
jaxbTargetDir = generatedSrcDir
}
repositories {
// removed corporate repository details for security
jcenter()
}
configurations {
jaxb
}
dependencies {
// Needed to generate JAX binding code
jaxb 'com.sun.xml.bind:jaxb-xjc:2.2.4-1'
}
def generatedResources = 'src/main/generated'
task jaxb(){
description 'Converts xsds to classes'
def jaxbTargetDir = file( generatedResources )
jaxbTargetDir.deleteDir()
doLast {
jaxbTargetDir.mkdirs()
ant.taskdef(name: 'xjc', classname: 'com.sun.tools.xjc.XJCTask', classpath: configurations.jaxb.asPath)
ant.jaxbTargetDir = jaxbTargetDir
ant.xjc(destdir: '${jaxbTargetDir}', package: 'com.pavan.xml.java.binding') {
schema(dir:'src/main/resources/xsd', includes: '*.xsd')
}
}
}
task generateSources(dependsOn: jaxb) {
description 'generates the resources defined by the external xsd\'s'
}
sourceSets {
main {
java {
srcDirs = ['src/main/java', 'src/main/generated']
}
}
}
compileJava.dependsOn jaxb
有沒有更好的方法可以做到這一點。 我正在瀏覽此鏈接,相對於XSD文件驗證XML文件的最佳方法是什么? 。 大多數答案來自2008年。我很好奇,現在是否有更好的方法可以做到這一點。
您正在使用JAXB,這是在Java中使用XML的“標准”方式。 此示例代碼顯示了一個以上的軟件包(由xjc生成)Java類和一個以上的針對您進行驗證的XSD,以及在Marshaller上設置了屬性。
// This part can be in a static initializer, with `jaxbContext` and `schema` as static variables.
JAXBContext jaxbContext = JAXBContext.newInstance("package1:package2");
try (InputStream xsdStream1 = EraMarshallingService.class.getResourceAsStream("/a.xsd");
InputStream xsdStream2 = EraMarshallingService.class.getResourceAsStream("/b.xsd");
InputStream xsdStream3 = EraMarshallingService.class.getResourceAsStream("/c.xsd");) {
SchemaFactory sf = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
Schema schema = sf.newSchema(new Source[] { new StreamSource(xsdStream1), new StreamSource(xsdStream2),
new StreamSource(xsdStream3));
}
// This part should be done for each document.
Marshaller marshaller = getJaxbContext().createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
marshaller.setProperty(Marshaller.JAXB_ENCODING, "UTF-8");
marshaller.setSchema(schema);
marshaller.marshal(jaxbRootElement, whereTheOutputIsGoing);
請注意,JAXBContext和Schema是線程安全的,通常可以在靜態初始化程序中創建一次並由多個線程永久重用。 通常應該為每個文檔創建一個新的編組器。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.