-
Bug
-
Resolution: Fixed
-
P4
-
None
-
7u51
-
x86_64
-
windows_7
FULL PRODUCT VERSION :
1.7.0_45
A DESCRIPTION OF THE PROBLEM :
xml 1.1 sax parsing can corrupt data for files over 8192 bytes long.
This applies to the version of xerces that is bundled in the jdk. Upgrading to a newer xerces version (from an external source) fixes the problem
A description of the problem can also be found here: https://community.oracle.com/thread/1626288
The "additional regression information" field of this issue contains a base64 encoded version of the "ivy.xml" file used in the sample code.
ADDITIONAL REGRESSION INFORMATION:
<?xml version="1.1" encoding="UTF-8"?>
<ivy-module version="2.0" xmlns:m="http://ant.apache.org/ivy/maven">
  <info organisation="com.xy.dra" module="radioarkiv-infrastructure" revision="0.2.25.5" status="release" publication="19700101005959">
    <description homepage=""/>
  </info>
  <configurations>
    <conf name="default" visibility="public" description="runtime dependencies and master artifact can be used with this conf" extends="runtime,master"/>
    <conf name="master" visibility="public" description="contains only the artifact published by this module itself, with no transitive dependencies"/>
    <conf name="compile" visibility="public" description="this is the default scope, used if none is specified. Compile dependencies are available in all classpaths."/>
    <conf name="provided" visibility="public" description="this is much like compile, but indicates you expect the JDK or a container to provide it. It is only available on the compilation classpath, and is not transitive."/>
    <conf name="runtime" visibility="public" description="this scope indicates that the dependency is not required for compilation, but is for execution. It is in the runtime and test classpaths, but not the compile classpath." extends="compile"/>
    <conf name="test" visibility="private" description="this scope indicates that the dependency is not required for normal use of the application, and is only available for the test compilation and execution phases." extends="runtime"/>
    <conf name="system" visibility="public" description="this scope is similar to provided except that you have to provide the JAR which contains it explicitly. The artifact is always available and is not looked up in a repository."/>
    <conf name="sources" visibility="public" description="this configuration contains the source artifact of this module, if any."/>
    <conf name="javadoc" visibility="public" description="this configuration contains the javadoc artifact of this module, if any."/>
    <conf name="optional" visibility="public" description="contains all optional dependencies"/>
  </configurations>
  <publications>
    <artifact name="radioarkiv-infrastructure" type="jar" ext="jar" conf="master"/>
  </publications>
  <dependencies>
    <dependency org="junit" name="junit" rev="4.11" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.hk2" name="spring-bridge" rev="2.2.0-b21" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="mysql" name="mysql-connector-java" rev="5.1.19" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.hk2.external" name="javax.inject" rev="2.2.0-b19" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.gluon" name="dataordbok" rev="0.99.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.google.guava" name="guava" rev="15.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.core" name="jersey-client" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.media" name="jersey-media-json-jackson" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-beans" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.common.fun" name="common-fun" rev="0.102.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.axonframework" name="axon-core" rev="2.0.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.jayway.jsonpath" name="json-path-assert" rev="0.9.0" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.slf4j" name="slf4j-api" rev="1.7.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="test-support-jersey" rev="0.2.25.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.containers" name="jersey-container-servlet-core" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.axonframework" name="axonframework-testsupport" rev="0.99.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.test-framework.providers" name="jersey-test-framework-provider-grizzly2" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="metadataworld" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-application" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.axonframework" name="axon-test" rev="2.0.6" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-web" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.common" name="common-core" rev="0.53" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-iri" rev="1.0.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.gluon" name="rolleliste" rev="0.99.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-api" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-core" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-arq" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="digas-vocabulary" rev="0.99.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.core" name="jersey-server" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="joda-time" name="joda-time" rev="2.3" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-tx" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="authority-registry" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="xerces" name="xercesImpl" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="xyzorg-model" rev="0.99.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hsqldb" name="hsqldb" rev="2.3.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hornetq" name="hornetq-jms-client" rev="2.3.0.Final" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-core" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.ext" name="jersey-spring3" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hornetq" name="hornetq-core-client" rev="2.3.0.Final" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.test-framework" name="jersey-test-framework-core" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-query-model-values" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="commons-dbcp" name="commons-dbcp" rev="1.4" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.granular8" name="specification-pattern" rev="1.1.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.easytesting" name="fest-assert" rev="1.4" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="ch.qos.logback" name="logback-classic" rev="1.0.13" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-context" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="javax.jms" name="javax.jms-api" rev="2.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.commons" name="commons-lang3" rev="3.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="ebuccdm-vocabulary" rev="0.100.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="javax.servlet" name="javax.servlet-api" rev="3.1.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.grizzly" name="grizzly-http-servlet" rev="2.3.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.mockito" name="mockito-core" rev="1.9.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.grizzly" name="grizzly-http-server" rev="2.3.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
  </dependencies>
</ivy-module>

STEPS TO FOLLOW TO REPRODUCE THE PROBLEM :
Run the enclosed test case
ACTUAL -
The test case fails with an exception, demonstrating corruption of data
REPRODUCIBILITY :
This bug can be reproduced occasionally.
---------- BEGIN SOURCE ----------
public static void main(String[] args) throws ParserConfigurationException, org.xml.sax.SAXException, IOException {
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
DefaultHandler handler = new DefaultHandler() {
public void startElement(String uri, String localName,String qName,
Attributes attributes) throws SAXException {
final String name = attributes.getValue("name");
final String org = attributes.getValue("org");
if ("jena-iri".equals(name)){
if (!"org.apache.jena".equals(org)){
throw new RuntimeException("Sax is broken:" + org);
}
}
}
};
final InputStream resourceAsStream = SaxTest.class.getResourceAsStream("ivy.xml");
saxParser.parse(resourceAsStream, handler);
resourceAsStream.close();
}
---------- END SOURCE ----------
CUSTOMER SUBMITTED WORKAROUND :
Avoid using embedded version of sax parser
1.7.0_45
A DESCRIPTION OF THE PROBLEM :
xml 1.1 sax parsing can corrupt data for files over 8192 bytes long.
This applies to the version of xerces that is bundled in the jdk. Upgrading to a newer xerces version (from an external source) fixes the problem
A description of the problem can also be found here: https://community.oracle.com/thread/1626288
The "additional regression information" field of this issue contains a base64 encoded version of the "ivy.xml" file used in the sample code.
ADDITIONAL REGRESSION INFORMATION:
<?xml version="1.1" encoding="UTF-8"?>
<ivy-module version="2.0" xmlns:m="http://ant.apache.org/ivy/maven">
  <info organisation="com.xy.dra" module="radioarkiv-infrastructure" revision="0.2.25.5" status="release" publication="19700101005959">
    <description homepage=""/>
  </info>
  <configurations>
    <conf name="default" visibility="public" description="runtime dependencies and master artifact can be used with this conf" extends="runtime,master"/>
    <conf name="master" visibility="public" description="contains only the artifact published by this module itself, with no transitive dependencies"/>
    <conf name="compile" visibility="public" description="this is the default scope, used if none is specified. Compile dependencies are available in all classpaths."/>
    <conf name="provided" visibility="public" description="this is much like compile, but indicates you expect the JDK or a container to provide it. It is only available on the compilation classpath, and is not transitive."/>
    <conf name="runtime" visibility="public" description="this scope indicates that the dependency is not required for compilation, but is for execution. It is in the runtime and test classpaths, but not the compile classpath." extends="compile"/>
    <conf name="test" visibility="private" description="this scope indicates that the dependency is not required for normal use of the application, and is only available for the test compilation and execution phases." extends="runtime"/>
    <conf name="system" visibility="public" description="this scope is similar to provided except that you have to provide the JAR which contains it explicitly. The artifact is always available and is not looked up in a repository."/>
    <conf name="sources" visibility="public" description="this configuration contains the source artifact of this module, if any."/>
    <conf name="javadoc" visibility="public" description="this configuration contains the javadoc artifact of this module, if any."/>
    <conf name="optional" visibility="public" description="contains all optional dependencies"/>
  </configurations>
  <publications>
    <artifact name="radioarkiv-infrastructure" type="jar" ext="jar" conf="master"/>
  </publications>
  <dependencies>
    <dependency org="junit" name="junit" rev="4.11" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.hk2" name="spring-bridge" rev="2.2.0-b21" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="mysql" name="mysql-connector-java" rev="5.1.19" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.hk2.external" name="javax.inject" rev="2.2.0-b19" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.gluon" name="dataordbok" rev="0.99.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.google.guava" name="guava" rev="15.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.core" name="jersey-client" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.media" name="jersey-media-json-jackson" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-beans" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.common.fun" name="common-fun" rev="0.102.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.axonframework" name="axon-core" rev="2.0.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.jayway.jsonpath" name="json-path-assert" rev="0.9.0" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.slf4j" name="slf4j-api" rev="1.7.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="test-support-jersey" rev="0.2.25.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.containers" name="jersey-container-servlet-core" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.axonframework" name="axonframework-testsupport" rev="0.99.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.test-framework.providers" name="jersey-test-framework-provider-grizzly2" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="metadataworld" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-application" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.axonframework" name="axon-test" rev="2.0.6" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-web" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.common" name="common-core" rev="0.53" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-iri" rev="1.0.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.gluon" name="rolleliste" rev="0.99.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-api" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-core" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-arq" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="digas-vocabulary" rev="0.99.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.core" name="jersey-server" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="joda-time" name="joda-time" rev="2.3" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-tx" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="authority-registry" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="xerces" name="xercesImpl" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="xyzorg-model" rev="0.99.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hsqldb" name="hsqldb" rev="2.3.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hornetq" name="hornetq-jms-client" rev="2.3.0.Final" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.jena" name="jena-core" rev="2.11.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.ext" name="jersey-spring3" rev="2.4.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.hornetq" name="hornetq-core-client" rev="2.3.0.Final" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.jersey.test-framework" name="jersey-test-framework-core" rev="2.3.1" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.dra" name="radioarkiv-query-model-values" rev="0.2.25.5" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="commons-dbcp" name="commons-dbcp" rev="1.4" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.granular8" name="specification-pattern" rev="1.1.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.easytesting" name="fest-assert" rev="1.4" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="ch.qos.logback" name="logback-classic" rev="1.0.13" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.springframework" name="spring-context" rev="4.0.0.RELEASE" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="javax.jms" name="javax.jms-api" rev="2.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.apache.commons" name="commons-lang3" rev="3.1" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="com.xy.mdb.models" name="ebuccdm-vocabulary" rev="0.100.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="javax.servlet" name="javax.servlet-api" rev="3.1.0" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.grizzly" name="grizzly-http-servlet" rev="2.3.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.mockito" name="mockito-core" rev="1.9.5" force="true" conf="test-&gt;runtime(*),master(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
    <dependency org="org.glassfish.grizzly" name="grizzly-http-server" rev="2.3.6" force="true" conf="compile-&gt;compile(*),master(*);runtime-&gt;runtime(*)">
      <exclude org="org.slf4j" module="slf4j-log4j12" name="*" type="*" ext="*" conf="" matcher="exact"/>
    </dependency>
  </dependencies>
</ivy-module>

STEPS TO FOLLOW TO REPRODUCE THE PROBLEM :
Run the enclosed test case
ACTUAL -
The test case fails with an exception, demonstrating corruption of data
REPRODUCIBILITY :
This bug can be reproduced occasionally.
---------- BEGIN SOURCE ----------
public static void main(String[] args) throws ParserConfigurationException, org.xml.sax.SAXException, IOException {
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
DefaultHandler handler = new DefaultHandler() {
public void startElement(String uri, String localName,String qName,
Attributes attributes) throws SAXException {
final String name = attributes.getValue("name");
final String org = attributes.getValue("org");
if ("jena-iri".equals(name)){
if (!"org.apache.jena".equals(org)){
throw new RuntimeException("Sax is broken:" + org);
}
}
}
};
final InputStream resourceAsStream = SaxTest.class.getResourceAsStream("ivy.xml");
saxParser.parse(resourceAsStream, handler);
resourceAsStream.close();
}
---------- END SOURCE ----------
CUSTOMER SUBMITTED WORKAROUND :
Avoid using embedded version of sax parser
- duplicates
-
JDK-8027359 XML parser returns incorrect parsing results
- Resolved