8306055: Add a built-in Catalog to JDK XML module
Reviewed-by: ihse, lancea, alanb
This commit is contained in:
parent
a4bd9e4d0b
commit
93bdc2a6db
@ -27,4 +27,5 @@ DISABLED_WARNINGS_java += lossy-conversions this-escape
|
|||||||
DOCLINT += -Xdoclint:all/protected \
|
DOCLINT += -Xdoclint:all/protected \
|
||||||
'-Xdoclint/package:$(call CommaList, javax.xml.catalog javax.xml.datatype \
|
'-Xdoclint/package:$(call CommaList, javax.xml.catalog javax.xml.datatype \
|
||||||
javax.xml.transform javax.xml.validation javax.xml.xpath)'
|
javax.xml.transform javax.xml.validation javax.xml.xpath)'
|
||||||
|
COPY += .dtd .xsd .xml
|
||||||
CLEAN += .properties
|
CLEAN += .properties
|
||||||
|
@ -46,7 +46,7 @@ import jdk.xml.internal.XMLSecurityManager;
|
|||||||
* @author K Venugopal
|
* @author K Venugopal
|
||||||
* @author Sunitha Reddy
|
* @author Sunitha Reddy
|
||||||
*
|
*
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class PropertyManager {
|
public class PropertyManager {
|
||||||
|
|
||||||
@ -150,10 +150,7 @@ public class PropertyManager {
|
|||||||
|
|
||||||
// Initialize Catalog features
|
// Initialize Catalog features
|
||||||
supportedProps.put(XMLConstants.USE_CATALOG, JdkXmlUtils.USE_CATALOG_DEFAULT);
|
supportedProps.put(XMLConstants.USE_CATALOG, JdkXmlUtils.USE_CATALOG_DEFAULT);
|
||||||
for (CatalogFeatures.Feature f : CatalogFeatures.Feature.values()) {
|
JdkXmlUtils.initCatalogFeatures(supportedProps);
|
||||||
supportedProps.put(f.getPropertyName(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
supportedProps.put(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
supportedProps.put(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,7 +74,7 @@ import jdk.xml.internal.XMLSecurityManager.Limit;
|
|||||||
* @author Eric Ye, IBM
|
* @author Eric Ye, IBM
|
||||||
* @author Sunitha Reddy, SUN Microsystems
|
* @author Sunitha Reddy, SUN Microsystems
|
||||||
*
|
*
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class XMLDocumentFragmentScannerImpl
|
public class XMLDocumentFragmentScannerImpl
|
||||||
extends XMLScanner
|
extends XMLScanner
|
||||||
@ -343,6 +343,13 @@ public class XMLDocumentFragmentScannerImpl
|
|||||||
*/
|
*/
|
||||||
protected String fAccessExternalDTD = EXTERNAL_ACCESS_DEFAULT;
|
protected String fAccessExternalDTD = EXTERNAL_ACCESS_DEFAULT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Properties to determine whether to use a user-specified Catalog:
|
||||||
|
* Feature USE_CATALOG, Resolve and Catalog File
|
||||||
|
*/
|
||||||
|
protected boolean fUseCatalog = true;
|
||||||
|
protected String fCatalogFile;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* standard uri conformant (strict uri).
|
* standard uri conformant (strict uri).
|
||||||
* http://apache.org/xml/features/standard-uri-conformant
|
* http://apache.org/xml/features/standard-uri-conformant
|
||||||
|
@ -43,9 +43,11 @@ import com.sun.xml.internal.stream.dtd.DTDGrammarUtil;
|
|||||||
import java.io.CharConversionException;
|
import java.io.CharConversionException;
|
||||||
import java.io.EOFException;
|
import java.io.EOFException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import javax.xml.XMLConstants;
|
||||||
import javax.xml.stream.events.XMLEvent;
|
import javax.xml.stream.events.XMLEvent;
|
||||||
import jdk.xml.internal.JdkConstants;
|
import jdk.xml.internal.JdkConstants;
|
||||||
import jdk.xml.internal.JdkProperty.State;
|
import jdk.xml.internal.JdkProperty.State;
|
||||||
|
import jdk.xml.internal.JdkXmlUtils;
|
||||||
import jdk.xml.internal.SecuritySupport;
|
import jdk.xml.internal.SecuritySupport;
|
||||||
import jdk.xml.internal.XMLSecurityManager.Limit;
|
import jdk.xml.internal.XMLSecurityManager.Limit;
|
||||||
|
|
||||||
@ -69,7 +71,7 @@ import jdk.xml.internal.XMLSecurityManager.Limit;
|
|||||||
* Refer to the table in unit-test javax.xml.stream.XMLStreamReaderTest.SupportDTD for changes
|
* Refer to the table in unit-test javax.xml.stream.XMLStreamReaderTest.SupportDTD for changes
|
||||||
* related to property SupportDTD.
|
* related to property SupportDTD.
|
||||||
* @author Joe Wang, Sun Microsystems
|
* @author Joe Wang, Sun Microsystems
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class XMLDocumentScannerImpl
|
public class XMLDocumentScannerImpl
|
||||||
extends XMLDocumentFragmentScannerImpl{
|
extends XMLDocumentFragmentScannerImpl{
|
||||||
@ -281,6 +283,9 @@ public class XMLDocumentScannerImpl
|
|||||||
fLoadExternalDTD = !((Boolean)propertyManager.getProperty(
|
fLoadExternalDTD = !((Boolean)propertyManager.getProperty(
|
||||||
Constants.ZEPHYR_PROPERTY_PREFIX + Constants.IGNORE_EXTERNAL_DTD));
|
Constants.ZEPHYR_PROPERTY_PREFIX + Constants.IGNORE_EXTERNAL_DTD));
|
||||||
|
|
||||||
|
fUseCatalog = (Boolean)propertyManager.getProperty(XMLConstants.USE_CATALOG);
|
||||||
|
fCatalogFile = (String)propertyManager.getProperty(JdkXmlUtils.CATALOG_FILES);
|
||||||
|
|
||||||
setScannerState(XMLEvent.START_DOCUMENT);
|
setScannerState(XMLEvent.START_DOCUMENT);
|
||||||
setDriver(fXMLDeclDriver);
|
setDriver(fXMLDeclDriver);
|
||||||
fSeenInternalSubset = false;
|
fSeenInternalSubset = false;
|
||||||
@ -327,6 +332,8 @@ public class XMLDocumentScannerImpl
|
|||||||
// xerces features
|
// xerces features
|
||||||
fLoadExternalDTD = componentManager.getFeature(LOAD_EXTERNAL_DTD, true);
|
fLoadExternalDTD = componentManager.getFeature(LOAD_EXTERNAL_DTD, true);
|
||||||
|
|
||||||
|
fUseCatalog = componentManager.getFeature(XMLConstants.USE_CATALOG, true);
|
||||||
|
fCatalogFile = (String)componentManager.getProperty(JdkXmlUtils.CATALOG_FILES);
|
||||||
fNamespaces = componentManager.getFeature(NAMESPACES, true);
|
fNamespaces = componentManager.getFeature(NAMESPACES, true);
|
||||||
|
|
||||||
fSeenInternalSubset = false;
|
fSeenInternalSubset = false;
|
||||||
|
@ -56,6 +56,7 @@ import javax.xml.catalog.CatalogManager;
|
|||||||
import javax.xml.catalog.CatalogResolver;
|
import javax.xml.catalog.CatalogResolver;
|
||||||
import javax.xml.stream.XMLInputFactory;
|
import javax.xml.stream.XMLInputFactory;
|
||||||
import javax.xml.transform.Source;
|
import javax.xml.transform.Source;
|
||||||
|
import jdk.xml.internal.JdkCatalog;
|
||||||
import jdk.xml.internal.JdkConstants;
|
import jdk.xml.internal.JdkConstants;
|
||||||
import jdk.xml.internal.JdkProperty;
|
import jdk.xml.internal.JdkProperty;
|
||||||
import jdk.xml.internal.JdkXmlUtils;
|
import jdk.xml.internal.JdkXmlUtils;
|
||||||
@ -93,7 +94,7 @@ import org.xml.sax.InputSource;
|
|||||||
* @author K.Venugopal SUN Microsystems
|
* @author K.Venugopal SUN Microsystems
|
||||||
* @author Neeraj Bajaj SUN Microsystems
|
* @author Neeraj Bajaj SUN Microsystems
|
||||||
* @author Sunitha Reddy SUN Microsystems
|
* @author Sunitha Reddy SUN Microsystems
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
||||||
|
|
||||||
@ -265,9 +266,6 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
/** Debug switching readers for encodings. */
|
/** Debug switching readers for encodings. */
|
||||||
private static final boolean DEBUG_ENCODINGS = false;
|
private static final boolean DEBUG_ENCODINGS = false;
|
||||||
|
|
||||||
// should be diplayed trace resolving messages
|
|
||||||
private static final boolean DEBUG_RESOLVER = false ;
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Data
|
// Data
|
||||||
//
|
//
|
||||||
@ -355,6 +353,7 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
|
|
||||||
/** Security Manager */
|
/** Security Manager */
|
||||||
protected XMLSecurityManager fSecurityManager = null;
|
protected XMLSecurityManager fSecurityManager = null;
|
||||||
|
XMLSecurityPropertyManager fSecurityPropertyMgr;
|
||||||
|
|
||||||
protected XMLLimitAnalyzer fLimitAnalyzer = null;
|
protected XMLLimitAnalyzer fLimitAnalyzer = null;
|
||||||
|
|
||||||
@ -418,8 +417,11 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
|
|
||||||
/** indicate whether Catalog should be used for resolving external resources */
|
/** indicate whether Catalog should be used for resolving external resources */
|
||||||
private boolean fUseCatalog = true;
|
private boolean fUseCatalog = true;
|
||||||
|
// user-specified Catalog Resolver
|
||||||
CatalogFeatures fCatalogFeatures;
|
CatalogFeatures fCatalogFeatures;
|
||||||
CatalogResolver fCatalogResolver;
|
CatalogResolver fCatalogResolver;
|
||||||
|
// the default JDK Catalog Resolver
|
||||||
|
CatalogResolver fDefCR;
|
||||||
|
|
||||||
private String fCatalogFile;
|
private String fCatalogFile;
|
||||||
private String fDefer;
|
private String fDefer;
|
||||||
@ -434,11 +436,16 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
* If this constructor is used to create the object, reset() should be invoked on this object
|
* If this constructor is used to create the object, reset() should be invoked on this object
|
||||||
*/
|
*/
|
||||||
public XMLEntityManager() {
|
public XMLEntityManager() {
|
||||||
|
this(null, new XMLSecurityManager(true));
|
||||||
|
}
|
||||||
|
|
||||||
|
public XMLEntityManager(XMLSecurityPropertyManager securityPropertyMgr, XMLSecurityManager securityManager) {
|
||||||
//for entity managers not created by parsers
|
//for entity managers not created by parsers
|
||||||
fSecurityManager = new XMLSecurityManager(true);
|
fSecurityManager = securityManager;
|
||||||
|
fSecurityPropertyMgr = securityPropertyMgr;
|
||||||
fEntityStorage = new XMLEntityStorage(this) ;
|
fEntityStorage = new XMLEntityStorage(this) ;
|
||||||
setScannerVersion(Constants.XML_VERSION_1_0);
|
setScannerVersion(Constants.XML_VERSION_1_0);
|
||||||
} // <init>()
|
}
|
||||||
|
|
||||||
/** Default constructor. */
|
/** Default constructor. */
|
||||||
public XMLEntityManager(PropertyManager propertyManager) {
|
public XMLEntityManager(PropertyManager propertyManager) {
|
||||||
@ -653,8 +660,12 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
URL location = new URL(expandedSystemId);
|
URL location = new URL(expandedSystemId);
|
||||||
URLConnection connect = location.openConnection();
|
URLConnection connect = location.openConnection();
|
||||||
if (!(connect instanceof HttpURLConnection)) {
|
if (!(connect instanceof HttpURLConnection)) {
|
||||||
|
if (expandedSystemId.startsWith("jrt:/java.xml")) {
|
||||||
|
stream = SecuritySupport.getInputStream(connect);
|
||||||
|
} else {
|
||||||
stream = connect.getInputStream();
|
stream = connect.getInputStream();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
boolean followRedirects = true;
|
boolean followRedirects = true;
|
||||||
|
|
||||||
@ -1012,75 +1023,128 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
ri = fResourceIdentifier;
|
ri = fResourceIdentifier;
|
||||||
}
|
}
|
||||||
ri.setValues(publicId, literalSystemId, baseSystemId, expandedSystemId);
|
ri.setValues(publicId, literalSystemId, baseSystemId, expandedSystemId);
|
||||||
if(DEBUG_RESOLVER){
|
|
||||||
System.out.println("BEFORE Calling resolveEntity") ;
|
|
||||||
}
|
|
||||||
|
|
||||||
fISCreatedByResolver = false;
|
fISCreatedByResolver = false;
|
||||||
//either of Stax or Xerces would be null
|
// Step 1: custom resolver, either StAX or Entity
|
||||||
if(fStaxEntityResolver != null){
|
if (fStaxEntityResolver != null) {
|
||||||
staxInputSource = fStaxEntityResolver.resolveEntity(ri);
|
staxInputSource = fStaxEntityResolver.resolveEntity(ri);
|
||||||
if(staxInputSource != null) {
|
} else if (fEntityResolver != null) {
|
||||||
fISCreatedByResolver = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(fEntityResolver != null){
|
|
||||||
xmlInputSource = fEntityResolver.resolveEntity(ri);
|
xmlInputSource = fEntityResolver.resolveEntity(ri);
|
||||||
if(xmlInputSource != null) {
|
if (xmlInputSource != null) {
|
||||||
|
//wrap it in StaxXMLInputSource
|
||||||
fISCreatedByResolver = true;
|
fISCreatedByResolver = true;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(xmlInputSource != null){
|
|
||||||
//wrap this XMLInputSource to StaxInputSource
|
|
||||||
staxInputSource = new StaxXMLInputSource(xmlInputSource, fISCreatedByResolver);
|
staxInputSource = new StaxXMLInputSource(xmlInputSource, fISCreatedByResolver);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (staxInputSource == null && fUseCatalog) {
|
|
||||||
if (fCatalogFeatures == null) {
|
|
||||||
fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve);
|
|
||||||
}
|
}
|
||||||
fCatalogFile = fCatalogFeatures.get(Feature.FILES);
|
|
||||||
if (fCatalogFile != null) {
|
// Step 2: custom catalog if specified
|
||||||
try {
|
if (staxInputSource == null && (fUseCatalog && fCatalogFile != null)) {
|
||||||
if (fCatalogResolver == null) {
|
if (fCatalogResolver == null) {
|
||||||
|
fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve);
|
||||||
fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures);
|
fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures);
|
||||||
}
|
}
|
||||||
InputSource is = fCatalogResolver.resolveEntity(publicId, literalSystemId);
|
|
||||||
if (is != null && !is.isEmpty()) {
|
staxInputSource = resolveWithCatalogStAX(fCatalogResolver, fCatalogFile, publicId, literalSystemId);
|
||||||
staxInputSource = new StaxXMLInputSource(new XMLInputSource(is, true), true);
|
|
||||||
}
|
|
||||||
} catch (CatalogException e) {
|
|
||||||
fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN,"CatalogException",
|
|
||||||
new Object[]{SecuritySupport.sanitizePath(fCatalogFile)},
|
|
||||||
XMLErrorReporter.SEVERITY_FATAL_ERROR, e );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// do default resolution
|
// Step 3: use the default JDK Catalog Resolver if Step 2's resolve is continue
|
||||||
//this works for both stax & Xerces, if staxInputSource is null,
|
if (staxInputSource == null && JdkXmlUtils.isResolveContinue(fCatalogFeatures)) {
|
||||||
//it means parser need to revert to default resolution
|
initJdkCatalogResolver();
|
||||||
if (staxInputSource == null) {
|
|
||||||
// REVISIT: when systemId is null, I think we should return null.
|
staxInputSource = resolveWithCatalogStAX(fDefCR, JdkCatalog.JDKCATALOG, publicId, literalSystemId);
|
||||||
// is this the right solution? -SG
|
}
|
||||||
//if (systemId != null)
|
|
||||||
|
// Step 4: default resolution if not resolved by a resolver and the RESOLVE
|
||||||
|
// feature is set to 'continue'
|
||||||
|
if (staxInputSource != null) {
|
||||||
|
fISCreatedByResolver = true;
|
||||||
|
} else if (JdkXmlUtils.isResolveContinue(fCatalogFeatures) &&
|
||||||
|
fSecurityManager.is(Limit.JDKCATALOG_RESOLVE, JdkConstants.CONTINUE)) {
|
||||||
staxInputSource = new StaxXMLInputSource(
|
staxInputSource = new StaxXMLInputSource(
|
||||||
new XMLInputSource(publicId, literalSystemId, baseSystemId, true), false);
|
new XMLInputSource(publicId, literalSystemId, baseSystemId, true), false);
|
||||||
}else if(staxInputSource.hasXMLStreamOrXMLEventReader()){
|
|
||||||
//Waiting for the clarification from EG. - nb
|
|
||||||
}
|
|
||||||
|
|
||||||
if (DEBUG_RESOLVER) {
|
|
||||||
System.err.println("XMLEntityManager.resolveEntity(" + publicId + ")");
|
|
||||||
System.err.println(" = " + xmlInputSource);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return staxInputSource;
|
return staxInputSource;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void initJdkCatalogResolver() {
|
||||||
|
if (fDefCR == null) {
|
||||||
|
fDefCR = fSecurityManager.getJDKCatalogResolver();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves the external resource using the Catalog specified and returns
|
||||||
|
* a StaxXMLInputSource.
|
||||||
|
*/
|
||||||
|
private StaxXMLInputSource resolveWithCatalogStAX(CatalogResolver cr, String cFile,
|
||||||
|
String publicId, String systemId) {
|
||||||
|
InputSource is = resolveWithCatalog(cr, cFile, publicId, systemId);
|
||||||
|
// note that empty source isn't considered resolved
|
||||||
|
if (is != null) {
|
||||||
|
return new StaxXMLInputSource(new XMLInputSource(is, true), true);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves the external resource using the Catalog specified and returns
|
||||||
|
* a InputSource.
|
||||||
|
*/
|
||||||
|
private InputSource resolveWithCatalog(CatalogResolver cr, String cFile,
|
||||||
|
String publicId, String systemId) {
|
||||||
|
if (cr != null) {
|
||||||
|
try {
|
||||||
|
return cr.resolveEntity(publicId, systemId);
|
||||||
|
} catch (CatalogException e) {
|
||||||
|
fErrorReporter.reportError(XMLMessageFormatter.XML_DOMAIN,"CatalogException",
|
||||||
|
new Object[]{SecuritySupport.sanitizePath(cFile)},
|
||||||
|
XMLErrorReporter.SEVERITY_FATAL_ERROR, e );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolves the external resource using the Catalog specified and returns
|
||||||
|
* a XMLInputSource. Since the Resolve method can be called from various processors,
|
||||||
|
* this method attempts to resolve the resource as an EntityResolver first
|
||||||
|
* and then URIResolver if no match is found.
|
||||||
|
*/
|
||||||
|
private XMLInputSource resolveEntityOrURI(CatalogResolver cr, String publicId, String systemId, String base) {
|
||||||
|
XMLInputSource xis = resolveEntity(cr, publicId, systemId, base);
|
||||||
|
|
||||||
|
if (xis != null) {
|
||||||
|
return xis;
|
||||||
|
} else if (systemId != null) {
|
||||||
|
Source source = null;
|
||||||
|
try {
|
||||||
|
source = cr.resolve(systemId, base);
|
||||||
|
} catch (CatalogException e) {
|
||||||
|
throw new XNIException(e);
|
||||||
|
}
|
||||||
|
if (source != null && !source.isEmpty()) {
|
||||||
|
return new XMLInputSource(publicId, source.getSystemId(), base, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private XMLInputSource resolveEntity(CatalogResolver cr, String publicId, String systemId, String base) {
|
||||||
|
InputSource is = null;
|
||||||
|
try {
|
||||||
|
if (publicId != null || systemId != null) {
|
||||||
|
is = cr.resolveEntity(publicId, systemId);
|
||||||
|
}
|
||||||
|
} catch (CatalogException e) {}
|
||||||
|
|
||||||
|
if (is != null && !is.isEmpty()) {
|
||||||
|
return new XMLInputSource(is, true);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Resolves the specified public and system identifiers. This
|
* Resolves the specified public and system identifiers. This
|
||||||
* method first attempts to resolve the entity based on the
|
* method first attempts to resolve the entity based on the
|
||||||
@ -1128,7 +1192,7 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
if (needExpand)
|
if (needExpand)
|
||||||
expandedSystemId = expandSystemId(literalSystemId, baseSystemId,false);
|
expandedSystemId = expandSystemId(literalSystemId, baseSystemId,false);
|
||||||
|
|
||||||
// give the entity resolver a chance
|
// Step 1: custom Entity resolver
|
||||||
XMLInputSource xmlInputSource = null;
|
XMLInputSource xmlInputSource = null;
|
||||||
|
|
||||||
if (fEntityResolver != null) {
|
if (fEntityResolver != null) {
|
||||||
@ -1137,65 +1201,32 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver {
|
|||||||
xmlInputSource = fEntityResolver.resolveEntity(resourceIdentifier);
|
xmlInputSource = fEntityResolver.resolveEntity(resourceIdentifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (xmlInputSource == null && fUseCatalog) {
|
// Step 2: custom catalog if specified
|
||||||
if (fCatalogFeatures == null) {
|
if ((publicId != null || literalSystemId != null || resourceIdentifier.getNamespace() !=null)
|
||||||
fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve);
|
&& xmlInputSource == null && (fUseCatalog && fCatalogFile != null)) {
|
||||||
}
|
|
||||||
fCatalogFile = fCatalogFeatures.get(Feature.FILES);
|
|
||||||
if (fCatalogFile != null) {
|
|
||||||
/*
|
|
||||||
since the method can be called from various processors, both
|
|
||||||
EntityResolver and URIResolver are used to attempt to find
|
|
||||||
a match
|
|
||||||
*/
|
|
||||||
InputSource is = null;
|
|
||||||
try {
|
|
||||||
if (fCatalogResolver == null) {
|
if (fCatalogResolver == null) {
|
||||||
|
fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve);
|
||||||
fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures);
|
fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures);
|
||||||
}
|
}
|
||||||
String pid = (publicId != null? publicId : resourceIdentifier.getNamespace());
|
String pid = (publicId != null? publicId : resourceIdentifier.getNamespace());
|
||||||
if (pid != null || literalSystemId != null) {
|
xmlInputSource = resolveEntityOrURI(fCatalogResolver, pid, literalSystemId, baseSystemId);
|
||||||
is = fCatalogResolver.resolveEntity(pid, literalSystemId);
|
|
||||||
}
|
|
||||||
} catch (CatalogException e) {}
|
|
||||||
|
|
||||||
if (is != null && !is.isEmpty()) {
|
|
||||||
xmlInputSource = new XMLInputSource(is, true);
|
|
||||||
} else if (literalSystemId != null) {
|
|
||||||
if (fCatalogResolver == null) {
|
|
||||||
fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Source source = null;
|
// Step 3: use the default JDK Catalog Resolver if Step 2's resolve is continue
|
||||||
try {
|
if ((publicId != null || literalSystemId != null)
|
||||||
source = fCatalogResolver.resolve(literalSystemId, baseSystemId);
|
&& xmlInputSource == null && JdkXmlUtils.isResolveContinue(fCatalogFeatures)) {
|
||||||
} catch (CatalogException e) {
|
initJdkCatalogResolver();
|
||||||
throw new XNIException(e);
|
// unlike a custom catalog, the JDK Catalog only contains entity references
|
||||||
}
|
xmlInputSource = resolveEntity(fDefCR, publicId, literalSystemId, baseSystemId);
|
||||||
if (source != null && !source.isEmpty()) {
|
|
||||||
xmlInputSource = new XMLInputSource(publicId, source.getSystemId(), baseSystemId, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// do default resolution
|
// Step 4: default resolution if not resolved by a resolver and the RESOLVE
|
||||||
// REVISIT: what's the correct behavior if the user provided an entity
|
// feature is set to 'continue'
|
||||||
// resolver (fEntityResolver != null), but resolveEntity doesn't return
|
if ((xmlInputSource == null) && JdkXmlUtils.isResolveContinue(fCatalogFeatures) &&
|
||||||
// an input source (xmlInputSource == null)?
|
fSecurityManager.is(Limit.JDKCATALOG_RESOLVE, JdkConstants.CONTINUE)) {
|
||||||
// do we do default resolution, or do we just return null? -SG
|
|
||||||
if (xmlInputSource == null) {
|
|
||||||
// REVISIT: when systemId is null, I think we should return null.
|
|
||||||
// is this the right solution? -SG
|
|
||||||
//if (systemId != null)
|
|
||||||
xmlInputSource = new XMLInputSource(publicId, literalSystemId, baseSystemId, false);
|
xmlInputSource = new XMLInputSource(publicId, literalSystemId, baseSystemId, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DEBUG_RESOLVER) {
|
|
||||||
System.err.println("XMLEntityManager.resolveEntity(" + publicId + ")");
|
|
||||||
System.err.println(" = " + xmlInputSource);
|
|
||||||
}
|
|
||||||
|
|
||||||
return xmlInputSource;
|
return xmlInputSource;
|
||||||
|
|
||||||
} // resolveEntity(XMLResourceIdentifier):XMLInputSource
|
} // resolveEntity(XMLResourceIdentifier):XMLInputSource
|
||||||
|
@ -63,7 +63,7 @@ import org.xml.sax.helpers.DefaultHandler;
|
|||||||
* @author Rajiv Mordani
|
* @author Rajiv Mordani
|
||||||
* @author Edwin Goei
|
* @author Edwin Goei
|
||||||
*
|
*
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
@SuppressWarnings("deprecation")
|
||||||
public class SAXParserImpl extends javax.xml.parsers.SAXParser
|
public class SAXParserImpl extends javax.xml.parsers.SAXParser
|
||||||
@ -402,7 +402,7 @@ public class SAXParserImpl extends javax.xml.parsers.SAXParser
|
|||||||
|
|
||||||
JAXPSAXParser(SAXParserImpl saxParser, XMLSecurityPropertyManager securityPropertyMgr,
|
JAXPSAXParser(SAXParserImpl saxParser, XMLSecurityPropertyManager securityPropertyMgr,
|
||||||
XMLSecurityManager securityManager) {
|
XMLSecurityManager securityManager) {
|
||||||
super();
|
super(null, null, securityPropertyMgr, securityManager);
|
||||||
fSAXParser = saxParser;
|
fSAXParser = saxParser;
|
||||||
fSecurityManager = securityManager;
|
fSecurityManager = securityManager;
|
||||||
fSecurityPropertyMgr = securityPropertyMgr;
|
fSecurityPropertyMgr = securityPropertyMgr;
|
||||||
|
@ -162,9 +162,6 @@ public final class XMLSchemaFactory extends SchemaFactory {
|
|||||||
|
|
||||||
// use catalog
|
// use catalog
|
||||||
fXMLSchemaLoader.setFeature(XMLConstants.USE_CATALOG, JdkXmlUtils.USE_CATALOG_DEFAULT);
|
fXMLSchemaLoader.setFeature(XMLConstants.USE_CATALOG, JdkXmlUtils.USE_CATALOG_DEFAULT);
|
||||||
for (Feature f : Feature.values()) {
|
|
||||||
fXMLSchemaLoader.setProperty(f.getPropertyName(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
fXMLSchemaLoader.setProperty(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
fXMLSchemaLoader.setProperty(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
||||||
fXmlFeatures = new JdkXmlFeatures(fSecurityManager.isSecureProcessing());
|
fXmlFeatures = new JdkXmlFeatures(fSecurityManager.isSecureProcessing());
|
||||||
|
@ -41,7 +41,7 @@ import org.xml.sax.SAXNotSupportedException;
|
|||||||
* @author Arnaud Le Hors, IBM
|
* @author Arnaud Le Hors, IBM
|
||||||
* @author Andy Clark, IBM
|
* @author Andy Clark, IBM
|
||||||
*
|
*
|
||||||
* @LastModified: Sep 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class SAXParser
|
public class SAXParser
|
||||||
extends AbstractSAXParser {
|
extends AbstractSAXParser {
|
||||||
@ -91,21 +91,21 @@ public class SAXParser
|
|||||||
*/
|
*/
|
||||||
public SAXParser(XMLParserConfiguration config) {
|
public SAXParser(XMLParserConfiguration config) {
|
||||||
super(config);
|
super(config);
|
||||||
initSecurityManager();
|
initSecurityManager(null, null);
|
||||||
} // <init>(XMLParserConfiguration)
|
} // <init>(XMLParserConfiguration)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a SAX parser using the dtd/xml schema parser configuration.
|
* Constructs a SAX parser using the dtd/xml schema parser configuration.
|
||||||
*/
|
*/
|
||||||
public SAXParser() {
|
public SAXParser() {
|
||||||
this(null, null);
|
this(null, null, null, null);
|
||||||
} // <init>()
|
} // <init>()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a SAX parser using the specified symbol table.
|
* Constructs a SAX parser using the specified symbol table.
|
||||||
*/
|
*/
|
||||||
public SAXParser(SymbolTable symbolTable) {
|
public SAXParser(SymbolTable symbolTable) {
|
||||||
this(symbolTable, null);
|
this(symbolTable, null, null, null);
|
||||||
} // <init>(SymbolTable)
|
} // <init>(SymbolTable)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -113,6 +113,11 @@ public class SAXParser
|
|||||||
* grammar pool.
|
* grammar pool.
|
||||||
*/
|
*/
|
||||||
public SAXParser(SymbolTable symbolTable, XMLGrammarPool grammarPool) {
|
public SAXParser(SymbolTable symbolTable, XMLGrammarPool grammarPool) {
|
||||||
|
this(symbolTable, grammarPool, null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SAXParser(SymbolTable symbolTable, XMLGrammarPool grammarPool,
|
||||||
|
XMLSecurityPropertyManager securityPropertyMgr, XMLSecurityManager securityManager) {
|
||||||
super(new XIncludeAwareParserConfiguration());
|
super(new XIncludeAwareParserConfiguration());
|
||||||
|
|
||||||
// set features
|
// set features
|
||||||
@ -128,7 +133,7 @@ public class SAXParser
|
|||||||
fConfiguration.setProperty(XMLGRAMMAR_POOL, grammarPool);
|
fConfiguration.setProperty(XMLGRAMMAR_POOL, grammarPool);
|
||||||
}
|
}
|
||||||
|
|
||||||
initSecurityManager();
|
initSecurityManager(securityPropertyMgr, securityManager);
|
||||||
} // <init>(SymbolTable,XMLGrammarPool)
|
} // <init>(SymbolTable,XMLGrammarPool)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -172,25 +177,4 @@ public class SAXParser
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Initiates the SecurityManager. This becomes necessary when the SAXParser
|
|
||||||
* is constructed directly by, for example, XMLReaderFactory rather than
|
|
||||||
* through SAXParserFactory.
|
|
||||||
*/
|
|
||||||
private void initSecurityManager() {
|
|
||||||
try {
|
|
||||||
if (securityManager == null) {
|
|
||||||
securityManager = new XMLSecurityManager(true);
|
|
||||||
super.setProperty(Constants.SECURITY_MANAGER, securityManager);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (securityPropertyManager == null) {
|
|
||||||
securityPropertyManager = new XMLSecurityPropertyManager();
|
|
||||||
super.setProperty(JdkConstants.XML_SECURITY_PROPERTY_MANAGER, securityPropertyManager);
|
|
||||||
}
|
|
||||||
} catch (SAXException e) {
|
|
||||||
Utils.dPrint(() -> e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} // class SAXParser
|
} // class SAXParser
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* reserved comment block
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT REMOVE OR ALTER!
|
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
@ -25,6 +24,7 @@ import com.sun.org.apache.xerces.internal.impl.Constants;
|
|||||||
import com.sun.org.apache.xerces.internal.util.FeatureState;
|
import com.sun.org.apache.xerces.internal.util.FeatureState;
|
||||||
import com.sun.org.apache.xerces.internal.util.NamespaceSupport;
|
import com.sun.org.apache.xerces.internal.util.NamespaceSupport;
|
||||||
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
||||||
|
import com.sun.org.apache.xerces.internal.utils.XMLSecurityPropertyManager;
|
||||||
import com.sun.org.apache.xerces.internal.xinclude.XIncludeHandler;
|
import com.sun.org.apache.xerces.internal.xinclude.XIncludeHandler;
|
||||||
import com.sun.org.apache.xerces.internal.xinclude.XIncludeNamespaceSupport;
|
import com.sun.org.apache.xerces.internal.xinclude.XIncludeNamespaceSupport;
|
||||||
import com.sun.org.apache.xerces.internal.xni.NamespaceContext;
|
import com.sun.org.apache.xerces.internal.xni.NamespaceContext;
|
||||||
@ -33,6 +33,7 @@ import com.sun.org.apache.xerces.internal.xni.grammars.XMLGrammarPool;
|
|||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;
|
||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;
|
||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;
|
||||||
|
import jdk.xml.internal.XMLSecurityManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class is the configuration used to parse XML 1.0 and XML 1.1 documents
|
* This class is the configuration used to parse XML 1.0 and XML 1.1 documents
|
||||||
@ -40,6 +41,7 @@ import com.sun.org.apache.xerces.internal.xni.parser.XMLDocumentSource;
|
|||||||
*
|
*
|
||||||
* @author Michael Glavassevich, IBM
|
* @author Michael Glavassevich, IBM
|
||||||
*
|
*
|
||||||
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
||||||
|
|
||||||
@ -88,7 +90,7 @@ public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
|||||||
|
|
||||||
/** Default constructor. */
|
/** Default constructor. */
|
||||||
public XIncludeAwareParserConfiguration() {
|
public XIncludeAwareParserConfiguration() {
|
||||||
this(null, null, null);
|
this(null, null, null, null, null);
|
||||||
} // <init>()
|
} // <init>()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -97,7 +99,7 @@ public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
|||||||
* @param symbolTable The symbol table to use.
|
* @param symbolTable The symbol table to use.
|
||||||
*/
|
*/
|
||||||
public XIncludeAwareParserConfiguration(SymbolTable symbolTable) {
|
public XIncludeAwareParserConfiguration(SymbolTable symbolTable) {
|
||||||
this(symbolTable, null, null);
|
this(symbolTable, null, null, null, null);
|
||||||
} // <init>(SymbolTable)
|
} // <init>(SymbolTable)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -111,7 +113,7 @@ public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
|||||||
public XIncludeAwareParserConfiguration(
|
public XIncludeAwareParserConfiguration(
|
||||||
SymbolTable symbolTable,
|
SymbolTable symbolTable,
|
||||||
XMLGrammarPool grammarPool) {
|
XMLGrammarPool grammarPool) {
|
||||||
this(symbolTable, grammarPool, null);
|
this(symbolTable, grammarPool, null, null, null);
|
||||||
} // <init>(SymbolTable,XMLGrammarPool)
|
} // <init>(SymbolTable,XMLGrammarPool)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -123,11 +125,15 @@ public class XIncludeAwareParserConfiguration extends XML11Configuration {
|
|||||||
* @param grammarPool The grammar pool to use.
|
* @param grammarPool The grammar pool to use.
|
||||||
* @param parentSettings The parent settings.
|
* @param parentSettings The parent settings.
|
||||||
*/
|
*/
|
||||||
public XIncludeAwareParserConfiguration(
|
public XIncludeAwareParserConfiguration(SymbolTable symbolTable, XMLGrammarPool grammarPool,
|
||||||
SymbolTable symbolTable,
|
|
||||||
XMLGrammarPool grammarPool,
|
|
||||||
XMLComponentManager parentSettings) {
|
XMLComponentManager parentSettings) {
|
||||||
super(symbolTable, grammarPool, parentSettings);
|
this(symbolTable, grammarPool, parentSettings, null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public XIncludeAwareParserConfiguration(SymbolTable symbolTable, XMLGrammarPool grammarPool,
|
||||||
|
XMLComponentManager parentSettings, XMLSecurityPropertyManager securityPropertyMgr,
|
||||||
|
XMLSecurityManager securityManager) {
|
||||||
|
super(symbolTable, grammarPool, parentSettings, securityPropertyMgr, securityManager);
|
||||||
|
|
||||||
final String[] recognizedFeatures = {
|
final String[] recognizedFeatures = {
|
||||||
ALLOW_UE_AND_NOTATION_EVENTS,
|
ALLOW_UE_AND_NOTATION_EVENTS,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2008, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2008, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
@ -46,6 +46,7 @@ import com.sun.org.apache.xerces.internal.util.FeatureState;
|
|||||||
import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;
|
import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;
|
||||||
import com.sun.org.apache.xerces.internal.util.PropertyState;
|
import com.sun.org.apache.xerces.internal.util.PropertyState;
|
||||||
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
import com.sun.org.apache.xerces.internal.util.SymbolTable;
|
||||||
|
import com.sun.org.apache.xerces.internal.utils.XMLSecurityPropertyManager;
|
||||||
import com.sun.org.apache.xerces.internal.xni.XMLDTDContentModelHandler;
|
import com.sun.org.apache.xerces.internal.xni.XMLDTDContentModelHandler;
|
||||||
import com.sun.org.apache.xerces.internal.xni.XMLDTDHandler;
|
import com.sun.org.apache.xerces.internal.xni.XMLDTDHandler;
|
||||||
import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler;
|
import com.sun.org.apache.xerces.internal.xni.XMLDocumentHandler;
|
||||||
@ -70,6 +71,7 @@ import javax.xml.XMLConstants;
|
|||||||
import javax.xml.catalog.CatalogFeatures;
|
import javax.xml.catalog.CatalogFeatures;
|
||||||
import jdk.xml.internal.JdkConstants;
|
import jdk.xml.internal.JdkConstants;
|
||||||
import jdk.xml.internal.JdkXmlUtils;
|
import jdk.xml.internal.JdkXmlUtils;
|
||||||
|
import jdk.xml.internal.XMLSecurityManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class is the configuration used to parse XML 1.0 and XML 1.1 documents.
|
* This class is the configuration used to parse XML 1.0 and XML 1.1 documents.
|
||||||
@ -78,7 +80,7 @@ import jdk.xml.internal.JdkXmlUtils;
|
|||||||
* @author Neil Graham, IBM
|
* @author Neil Graham, IBM
|
||||||
* @author Michael Glavassevich, IBM
|
* @author Michael Glavassevich, IBM
|
||||||
*
|
*
|
||||||
* @LastModified: May 2021
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class XML11Configuration extends ParserConfigurationSettings
|
public class XML11Configuration extends ParserConfigurationSettings
|
||||||
implements XMLPullParserConfiguration, XML11Configurable {
|
implements XMLPullParserConfiguration, XML11Configurable {
|
||||||
@ -432,7 +434,7 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
|
|
||||||
/** Default constructor. */
|
/** Default constructor. */
|
||||||
public XML11Configuration() {
|
public XML11Configuration() {
|
||||||
this(null, null, null);
|
this(null, null, null, null, null);
|
||||||
} // <init>()
|
} // <init>()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -441,7 +443,7 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
* @param symbolTable The symbol table to use.
|
* @param symbolTable The symbol table to use.
|
||||||
*/
|
*/
|
||||||
public XML11Configuration(SymbolTable symbolTable) {
|
public XML11Configuration(SymbolTable symbolTable) {
|
||||||
this(symbolTable, null, null);
|
this(symbolTable, null, null, null, null);
|
||||||
} // <init>(SymbolTable)
|
} // <init>(SymbolTable)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -456,7 +458,7 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
* @param grammarPool The grammar pool to use.
|
* @param grammarPool The grammar pool to use.
|
||||||
*/
|
*/
|
||||||
public XML11Configuration(SymbolTable symbolTable, XMLGrammarPool grammarPool) {
|
public XML11Configuration(SymbolTable symbolTable, XMLGrammarPool grammarPool) {
|
||||||
this(symbolTable, grammarPool, null);
|
this(symbolTable, grammarPool, null, null, null);
|
||||||
} // <init>(SymbolTable,XMLGrammarPool)
|
} // <init>(SymbolTable,XMLGrammarPool)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -471,10 +473,14 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
* @param grammarPool The grammar pool to use.
|
* @param grammarPool The grammar pool to use.
|
||||||
* @param parentSettings The parent settings.
|
* @param parentSettings The parent settings.
|
||||||
*/
|
*/
|
||||||
public XML11Configuration(
|
public XML11Configuration(SymbolTable symbolTable, XMLGrammarPool grammarPool,
|
||||||
SymbolTable symbolTable,
|
|
||||||
XMLGrammarPool grammarPool,
|
|
||||||
XMLComponentManager parentSettings) {
|
XMLComponentManager parentSettings) {
|
||||||
|
this(symbolTable, grammarPool, parentSettings, null, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public XML11Configuration(SymbolTable symbolTable, XMLGrammarPool grammarPool,
|
||||||
|
XMLComponentManager parentSettings, XMLSecurityPropertyManager securityPropertyMgr,
|
||||||
|
XMLSecurityManager securityManager) {
|
||||||
|
|
||||||
super(parentSettings);
|
super(parentSettings);
|
||||||
|
|
||||||
@ -592,7 +598,7 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
fProperties.put(XMLGRAMMAR_POOL, fGrammarPool);
|
fProperties.put(XMLGRAMMAR_POOL, fGrammarPool);
|
||||||
}
|
}
|
||||||
|
|
||||||
fEntityManager = new XMLEntityManager();
|
fEntityManager = new XMLEntityManager(securityPropertyMgr, securityManager);
|
||||||
fProperties.put(ENTITY_MANAGER, fEntityManager);
|
fProperties.put(ENTITY_MANAGER, fEntityManager);
|
||||||
addCommonComponent(fEntityManager);
|
addCommonComponent(fEntityManager);
|
||||||
|
|
||||||
@ -640,11 +646,6 @@ public class XML11Configuration extends ParserConfigurationSettings
|
|||||||
// REVISIT: What is the right thing to do? -Ac
|
// REVISIT: What is the right thing to do? -Ac
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialize Catalog features
|
|
||||||
for( CatalogFeatures.Feature f : CatalogFeatures.Feature.values()) {
|
|
||||||
fProperties.put(f.getPropertyName(), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
setProperty(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
setProperty(JdkConstants.CDATA_CHUNK_SIZE, JdkConstants.CDATA_CHUNK_SIZE_DEFAULT);
|
||||||
|
|
||||||
fConfigUpdated = false;
|
fConfigUpdated = false;
|
||||||
|
@ -28,7 +28,9 @@ import com.sun.org.apache.xerces.internal.xni.XNIException;
|
|||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLInputSource;
|
||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLParserConfiguration;
|
||||||
import jdk.xml.internal.JdkConstants;
|
import jdk.xml.internal.JdkConstants;
|
||||||
|
import jdk.xml.internal.Utils;
|
||||||
import jdk.xml.internal.XMLSecurityManager;
|
import jdk.xml.internal.XMLSecurityManager;
|
||||||
|
import org.xml.sax.SAXException;
|
||||||
import org.xml.sax.SAXNotSupportedException;
|
import org.xml.sax.SAXNotSupportedException;
|
||||||
import org.xml.sax.SAXNotRecognizedException;
|
import org.xml.sax.SAXNotRecognizedException;
|
||||||
|
|
||||||
@ -48,7 +50,7 @@ import org.xml.sax.SAXNotRecognizedException;
|
|||||||
*
|
*
|
||||||
* @author Arnaud Le Hors, IBM
|
* @author Arnaud Le Hors, IBM
|
||||||
* @author Andy Clark, IBM
|
* @author Andy Clark, IBM
|
||||||
* @LastModified: July 2023
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public abstract class XMLParser {
|
public abstract class XMLParser {
|
||||||
|
|
||||||
@ -127,20 +129,29 @@ public abstract class XMLParser {
|
|||||||
public void parse(XMLInputSource inputSource)
|
public void parse(XMLInputSource inputSource)
|
||||||
throws XNIException, IOException {
|
throws XNIException, IOException {
|
||||||
// null indicates that the parser is called directly, initialize them
|
// null indicates that the parser is called directly, initialize them
|
||||||
if (securityManager == null) {
|
initSecurityManager(null, null);
|
||||||
securityManager = new XMLSecurityManager(true);
|
|
||||||
fConfiguration.setProperty(Constants.SECURITY_MANAGER, securityManager);
|
|
||||||
}
|
|
||||||
if (securityPropertyManager == null) {
|
|
||||||
securityPropertyManager = new XMLSecurityPropertyManager();
|
|
||||||
fConfiguration.setProperty(JdkConstants.XML_SECURITY_PROPERTY_MANAGER, securityPropertyManager);
|
|
||||||
}
|
|
||||||
|
|
||||||
reset();
|
reset();
|
||||||
fConfiguration.parse(inputSource);
|
fConfiguration.parse(inputSource);
|
||||||
|
|
||||||
} // parse(XMLInputSource)
|
} // parse(XMLInputSource)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initiates the SecurityManager. This becomes necessary when the Parser
|
||||||
|
* is constructed directly by, for example, XMLReaderFactory rather than
|
||||||
|
* through SAXParserFactory.
|
||||||
|
*/
|
||||||
|
void initSecurityManager(XMLSecurityPropertyManager spm, XMLSecurityManager sm) {
|
||||||
|
if (securityManager == null) {
|
||||||
|
securityManager = sm != null ? sm : new XMLSecurityManager(true);
|
||||||
|
}
|
||||||
|
fConfiguration.setProperty(Constants.SECURITY_MANAGER, securityManager);
|
||||||
|
|
||||||
|
if (securityPropertyManager == null) {
|
||||||
|
securityPropertyManager = spm != null ? spm : new XMLSecurityPropertyManager();
|
||||||
|
}
|
||||||
|
fConfiguration.setProperty(JdkConstants.XML_SECURITY_PROPERTY_MANAGER, securityPropertyManager);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// Protected methods
|
// Protected methods
|
||||||
//
|
//
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2019, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
@ -28,6 +28,7 @@ import java.util.Arrays;
|
|||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import jdk.xml.internal.JdkXmlUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class implements the basic operations for managing parser
|
* This class implements the basic operations for managing parser
|
||||||
@ -42,7 +43,7 @@ import java.util.Map;
|
|||||||
*
|
*
|
||||||
* @author Andy Clark, IBM
|
* @author Andy Clark, IBM
|
||||||
*
|
*
|
||||||
* @LastModified: Apr 2019
|
* @LastModified: Nov 2023
|
||||||
*/
|
*/
|
||||||
public class ParserConfigurationSettings
|
public class ParserConfigurationSettings
|
||||||
implements XMLComponentManager {
|
implements XMLComponentManager {
|
||||||
@ -97,6 +98,8 @@ public class ParserConfigurationSettings
|
|||||||
// save parent
|
// save parent
|
||||||
fParentSettings = parent;
|
fParentSettings = parent;
|
||||||
|
|
||||||
|
// Initialize Catalog features
|
||||||
|
JdkXmlUtils.initCatalogFeatures(fProperties);
|
||||||
} // <init>(XMLComponentManager)
|
} // <init>(XMLComponentManager)
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -165,7 +165,7 @@ class Util {
|
|||||||
case SCHEME_FILE:
|
case SCHEME_FILE:
|
||||||
String path = uri.getPath();
|
String path = uri.getPath();
|
||||||
File f1 = new File(path);
|
File f1 = new File(path);
|
||||||
if (f1.isFile()) {
|
if (SecuritySupport.isFile(f1)) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
46
src/java.xml/share/classes/jdk/xml/internal/JdkCatalog.java
Normal file
46
src/java.xml/share/classes/jdk/xml/internal/JdkCatalog.java
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Oracle designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Oracle in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package jdk.xml.internal;
|
||||||
|
|
||||||
|
import java.net.URI;
|
||||||
|
import javax.xml.catalog.Catalog;
|
||||||
|
import javax.xml.catalog.CatalogFeatures;
|
||||||
|
import javax.xml.catalog.CatalogManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents the built-in Catalog that hosts the DTDs for the Java platform.
|
||||||
|
*/
|
||||||
|
public class JdkCatalog {
|
||||||
|
public static final String JDKCATALOG = "/jdk/xml/internal/jdkcatalog/JDKCatalog.xml";
|
||||||
|
private static final String JDKCATALOG_URL = SecuritySupport.getResource(JDKCATALOG).toExternalForm();
|
||||||
|
public static Catalog catalog;
|
||||||
|
|
||||||
|
public static void init(String resolve) {
|
||||||
|
if (catalog == null) {
|
||||||
|
CatalogFeatures cf = JdkXmlUtils.getCatalogFeatures(null, JDKCATALOG_URL, null, resolve);
|
||||||
|
catalog = CatalogManager.catalog(cf, URI.create(JDKCATALOG_URL));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -291,6 +291,7 @@ public final class JdkConstants {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* System Property for the DTD property
|
* System Property for the DTD property
|
||||||
|
* @since 22
|
||||||
*/
|
*/
|
||||||
public static final String DTD_PROPNAME = "jdk.xml.dtd.support";
|
public static final String DTD_PROPNAME = "jdk.xml.dtd.support";
|
||||||
|
|
||||||
@ -299,6 +300,17 @@ public final class JdkConstants {
|
|||||||
public static final int IGNORE = 1;
|
public static final int IGNORE = 1;
|
||||||
public static final int DENY = 2;
|
public static final int DENY = 2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* System Property for the JDKCatalog' RESOLVE property
|
||||||
|
* @since 22
|
||||||
|
*/
|
||||||
|
public static final String JDKCATALOG_RESOLVE = "jdk.xml.jdkCatalog.resolve";
|
||||||
|
|
||||||
|
// Catalog Resolve Integer mappings for String values
|
||||||
|
public static final int CONTINUE = 0;
|
||||||
|
//public static final int IGNORE = 1; // same as that of DTD
|
||||||
|
public static final int STRICT = 2;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Values for a feature
|
* Values for a feature
|
||||||
*/
|
*/
|
||||||
|
@ -31,6 +31,7 @@ import com.sun.org.apache.xerces.internal.jaxp.SAXParserFactoryImpl;
|
|||||||
import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;
|
import com.sun.org.apache.xerces.internal.util.ParserConfigurationSettings;
|
||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLComponentManager;
|
||||||
import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;
|
import com.sun.org.apache.xerces.internal.xni.parser.XMLConfigurationException;
|
||||||
|
import java.util.Map;
|
||||||
import javax.xml.XMLConstants;
|
import javax.xml.XMLConstants;
|
||||||
import javax.xml.catalog.CatalogFeatures;
|
import javax.xml.catalog.CatalogFeatures;
|
||||||
import javax.xml.catalog.CatalogFeatures.Feature;
|
import javax.xml.catalog.CatalogFeatures.Feature;
|
||||||
@ -156,6 +157,31 @@ public class JdkXmlUtils {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize catalog features, including setting the default values and reading
|
||||||
|
* from the JAXP configuration file and System Properties.
|
||||||
|
*
|
||||||
|
* @param properties the Map object that holds the properties
|
||||||
|
*/
|
||||||
|
public static void initCatalogFeatures(Map<String, Object> properties) {
|
||||||
|
CatalogFeatures cf = getCatalogFeatures();
|
||||||
|
for( CatalogFeatures.Feature f : CatalogFeatures.Feature.values()) {
|
||||||
|
properties.put(f.getPropertyName(), cf.get(f));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an instance of a CatalogFeatures with default settings.
|
||||||
|
* Note: the CatalogFeatures is initialized with settings in the following
|
||||||
|
* order:
|
||||||
|
* Default values -> values in the config -> values set with System Properties
|
||||||
|
*
|
||||||
|
* @return an instance of a CatalogFeatures
|
||||||
|
*/
|
||||||
|
public static CatalogFeatures getCatalogFeatures() {
|
||||||
|
return CatalogFeatures.builder().build();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an instance of a CatalogFeatures.
|
* Creates an instance of a CatalogFeatures.
|
||||||
*
|
*
|
||||||
|
@ -30,6 +30,7 @@ import java.io.FileNotFoundException;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
import java.net.URLConnection;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.security.AccessController;
|
import java.security.AccessController;
|
||||||
import java.security.CodeSource;
|
import java.security.CodeSource;
|
||||||
@ -266,6 +267,18 @@ public class SecuritySupport {
|
|||||||
-> f.exists()));
|
-> f.exists()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests whether the input is file.
|
||||||
|
*
|
||||||
|
* @param f the file to be tested
|
||||||
|
* @return true if the input is file, false otherwise
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
|
public static boolean isFile(final File f) {
|
||||||
|
return (AccessController.doPrivileged((PrivilegedAction<Boolean>) ()
|
||||||
|
-> f.isFile()));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates and returns a new FileInputStream from a file.
|
* Creates and returns a new FileInputStream from a file.
|
||||||
* @param file the specified file
|
* @param file the specified file
|
||||||
@ -283,6 +296,23 @@ public class SecuritySupport {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an InputStream from a URLConnection.
|
||||||
|
* @param uc the URLConnection
|
||||||
|
* @return the InputStream
|
||||||
|
* @throws IOException if an I/O error occurs while creating the input stream
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
|
public static InputStream getInputStream(final URLConnection uc)
|
||||||
|
throws IOException {
|
||||||
|
try {
|
||||||
|
return AccessController.doPrivileged((PrivilegedExceptionAction<InputStream>) ()
|
||||||
|
-> uc.getInputStream());
|
||||||
|
} catch (PrivilegedActionException e) {
|
||||||
|
throw (IOException) e.getException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the resource as a stream.
|
* Returns the resource as a stream.
|
||||||
* @param name the resource name
|
* @param name the resource name
|
||||||
@ -294,6 +324,17 @@ public class SecuritySupport {
|
|||||||
SecuritySupport.class.getResourceAsStream("/"+name));
|
SecuritySupport.class.getResourceAsStream("/"+name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the resource by the name.
|
||||||
|
* @param name the resource name
|
||||||
|
* @return the resource
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
|
public static URL getResource(final String name) {
|
||||||
|
return AccessController.doPrivileged((PrivilegedAction<URL>) () ->
|
||||||
|
SecuritySupport.class.getResource(name));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a resource bundle using the specified base name, the default locale, and the caller's class loader.
|
* Gets a resource bundle using the specified base name, the default locale, and the caller's class loader.
|
||||||
* @param bundle the base name of the resource bundle, a fully qualified class name
|
* @param bundle the base name of the resource bundle, a fully qualified class name
|
||||||
|
@ -32,6 +32,9 @@ import java.util.Map;
|
|||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
import javax.xml.catalog.CatalogManager;
|
||||||
|
import javax.xml.catalog.CatalogResolver;
|
||||||
|
import javax.xml.catalog.CatalogResolver.NotFoundAction;
|
||||||
import javax.xml.stream.XMLInputFactory;
|
import javax.xml.stream.XMLInputFactory;
|
||||||
import jdk.xml.internal.JdkProperty.State;
|
import jdk.xml.internal.JdkProperty.State;
|
||||||
import jdk.xml.internal.JdkProperty.ImplPropMap;
|
import jdk.xml.internal.JdkProperty.ImplPropMap;
|
||||||
@ -67,15 +70,30 @@ public final class XMLSecurityManager {
|
|||||||
DTD_MAP = Collections.unmodifiableMap(map);
|
DTD_MAP = Collections.unmodifiableMap(map);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Valid values for Catalog Resolve, and mappings between the string and
|
||||||
|
// interger values
|
||||||
|
static final Map<String, Integer> CR_MAP;
|
||||||
|
// Source Level JDK 8
|
||||||
|
static {
|
||||||
|
Map<String, Integer> map = new HashMap<>();
|
||||||
|
map.put("continue", 0);
|
||||||
|
map.put("ignore", 1);
|
||||||
|
map.put("strict", 2);
|
||||||
|
CR_MAP = Collections.unmodifiableMap(map);
|
||||||
|
}
|
||||||
|
|
||||||
// Value converter for properties of type Boolean
|
// Value converter for properties of type Boolean
|
||||||
private static final BooleanMapper BOOLMAPPER = new BooleanMapper();
|
private static final BooleanMapper BOOLMAPPER = new BooleanMapper();
|
||||||
|
|
||||||
// Value converter for properties of type Integer
|
// Value converter for properties of type Integer
|
||||||
private static final IntegerMapper INTMAPPER = new IntegerMapper();
|
private static final IntegerMapper INTMAPPER = new IntegerMapper();
|
||||||
|
|
||||||
// DTD value map
|
// DTD value mapper
|
||||||
private static final StringMapper DTDMAPPER = new StringMapper(DTD_MAP);
|
private static final StringMapper DTDMAPPER = new StringMapper(DTD_MAP);
|
||||||
|
|
||||||
|
// Catalog Resolve value mapper
|
||||||
|
private static final StringMapper CRMAPPER = new StringMapper(CR_MAP);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Limits managed by the security manager
|
* Limits managed by the security manager
|
||||||
*/
|
*/
|
||||||
@ -109,6 +127,8 @@ public final class XMLSecurityManager {
|
|||||||
JdkConstants.ALLOW, JdkConstants.ALLOW, Processor.PARSER, DTDMAPPER),
|
JdkConstants.ALLOW, JdkConstants.ALLOW, Processor.PARSER, DTDMAPPER),
|
||||||
XERCES_DISALLOW_DTD("disallowDTD", DISALLOW_DTD, null, null, 0, 0, Processor.PARSER, BOOLMAPPER),
|
XERCES_DISALLOW_DTD("disallowDTD", DISALLOW_DTD, null, null, 0, 0, Processor.PARSER, BOOLMAPPER),
|
||||||
STAX_SUPPORT_DTD("supportDTD", XMLInputFactory.SUPPORT_DTD, null, null, 1, 1, Processor.PARSER, BOOLMAPPER),
|
STAX_SUPPORT_DTD("supportDTD", XMLInputFactory.SUPPORT_DTD, null, null, 1, 1, Processor.PARSER, BOOLMAPPER),
|
||||||
|
JDKCATALOG_RESOLVE("JDKCatalogResolve", JdkConstants.JDKCATALOG_RESOLVE, JdkConstants.JDKCATALOG_RESOLVE, null,
|
||||||
|
JdkConstants.CONTINUE, JdkConstants.CONTINUE, Processor.PARSER, CRMAPPER),
|
||||||
;
|
;
|
||||||
|
|
||||||
final String key;
|
final String key;
|
||||||
@ -266,6 +286,48 @@ public final class XMLSecurityManager {
|
|||||||
|
|
||||||
//read system properties or the config file (jaxp.properties by default)
|
//read system properties or the config file (jaxp.properties by default)
|
||||||
readSystemProperties();
|
readSystemProperties();
|
||||||
|
// prepare the JDK Catalog
|
||||||
|
prepareCatalog();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag indicating whether the JDK Catalog has been initialized
|
||||||
|
*/
|
||||||
|
static volatile boolean jdkcatalogInitialized = false;
|
||||||
|
private final Object lock = new Object();
|
||||||
|
|
||||||
|
private void prepareCatalog() {
|
||||||
|
if (!jdkcatalogInitialized) {
|
||||||
|
synchronized (lock) {
|
||||||
|
if (!jdkcatalogInitialized) {
|
||||||
|
jdkcatalogInitialized = true;
|
||||||
|
String resolve = getLimitValueAsString(Limit.JDKCATALOG_RESOLVE);
|
||||||
|
JdkCatalog.init(resolve);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the JDKCatalogResolver with the current setting of the RESOLVE
|
||||||
|
* property.
|
||||||
|
*
|
||||||
|
* @return the JDKCatalogResolver
|
||||||
|
*/
|
||||||
|
public CatalogResolver getJDKCatalogResolver() {
|
||||||
|
String resolve = getLimitValueAsString(Limit.JDKCATALOG_RESOLVE);
|
||||||
|
return CatalogManager.catalogResolver(JdkCatalog.catalog, toActionType(resolve));
|
||||||
|
}
|
||||||
|
|
||||||
|
// convert the string value of the RESOLVE property to the corresponding
|
||||||
|
// action type
|
||||||
|
private NotFoundAction toActionType(String resolve) {
|
||||||
|
for (NotFoundAction type : NotFoundAction.values()) {
|
||||||
|
if (type.toString().equals(resolve)) {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -0,0 +1,41 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Oracle designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Oracle in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
-->
|
||||||
|
<!--
|
||||||
|
Catalog of DTDs for the Java platform
|
||||||
|
|
||||||
|
@implNote: DTDs in the built-in catalog are resolved against its URI and the
|
||||||
|
xml:base attribute. The preferences.dtd for example is resolved as:
|
||||||
|
|
||||||
|
jrt:/java.xml/jdk/xml/internal/jdkcatalog/java/dtd/preferences.dtd
|
||||||
|
-->
|
||||||
|
<catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog">
|
||||||
|
<group id="javadtds" prefer = "system" xml:base = "java/dtd/">
|
||||||
|
<system systemId="http://java.sun.com/dtd/preferences.dtd" uri="preferences.dtd"/>
|
||||||
|
<system systemId="http://java.sun.com/dtd/properties.dtd" uri="properties.dtd"/>
|
||||||
|
</group>
|
||||||
|
</catalog>
|
@ -0,0 +1,110 @@
|
|||||||
|
<!--
|
||||||
|
Copyright 2001 Sun Microsystems, Inc. 901 San Antonio Road,
|
||||||
|
Palo Alto, CA 94303, U.S.A. All rights reserved.
|
||||||
|
|
||||||
|
This product or document is protected by copyright and distributed
|
||||||
|
under licenses restricting its use, copying, distribution, and
|
||||||
|
decompilation. No part of this product or documentation may be
|
||||||
|
reproduced in any form by any means without prior written authorization
|
||||||
|
of Sun and its licensors, if any.
|
||||||
|
|
||||||
|
Third party software, including font technology, is copyrighted and
|
||||||
|
licensed from Sun suppliers.
|
||||||
|
|
||||||
|
Sun, Sun Microsystems, the Sun Logo, Solaris, Java, JavaServer Pages, Java
|
||||||
|
Naming and Directory Interface, JDBC, JDK, JavaMail and Enterprise JavaBeans,
|
||||||
|
are trademarks or registered trademarks of Sun Microsystems, Inc in the U.S.
|
||||||
|
and other countries.
|
||||||
|
|
||||||
|
All SPARC trademarks are used under license and are trademarks
|
||||||
|
or registered trademarks of SPARC International, Inc.
|
||||||
|
in the U.S. and other countries. Products bearing SPARC
|
||||||
|
trademarks are based upon an architecture developed by Sun Microsystems, Inc.
|
||||||
|
|
||||||
|
PostScript is a registered trademark of Adobe Systems, Inc.
|
||||||
|
|
||||||
|
Federal Acquisitions: Commercial Software - Government Users Subject to
|
||||||
|
Standard License Terms and Conditions.
|
||||||
|
|
||||||
|
DOCUMENTATION IS PROVIDED "AS IS" AND ALL EXPRESS OR IMPLIED
|
||||||
|
CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY
|
||||||
|
IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE OR NON-INFRINGEMENT, ARE DISCLAIMED, EXCEPT
|
||||||
|
TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD TO BE LEGALLY
|
||||||
|
INVALID.
|
||||||
|
|
||||||
|
_________________________________________________________________________
|
||||||
|
|
||||||
|
Copyright 2000-2001 Sun Microsystems, Inc.,
|
||||||
|
901 San Antonio Road, Palo Alto, CA 94303, Etats-Unis.
|
||||||
|
Tous droits re'serve's.
|
||||||
|
|
||||||
|
|
||||||
|
Ce produit ou document est prote'ge' par un copyright et distribue' avec
|
||||||
|
des licences qui en restreignent l'utilisation, la copie, la distribution,
|
||||||
|
et la de'compilation. Aucune partie de ce produit ou de sa documentation
|
||||||
|
associe'e ne peut e^tre reproduite sous aucune forme, par quelque moyen
|
||||||
|
que ce soit, sans l'autorisation pre'alable et e'crite de Sun et de ses
|
||||||
|
bailleurs de licence, s'il y en a.
|
||||||
|
|
||||||
|
Le logiciel de'tenu par des tiers, et qui comprend la technologie
|
||||||
|
relative aux polices de caracte`res, est prote'ge' par un copyright
|
||||||
|
et licencie' par des fournisseurs de Sun.
|
||||||
|
|
||||||
|
Sun, Sun Microsystems, le logo Sun, Solaris, Java, JavaServer Pages, Java
|
||||||
|
Naming and Directory Interface, JDBC, JDK, JavaMail, et Enterprise JavaBeans,
|
||||||
|
sont des marques de fabrique ou des marques de'pose'es de Sun
|
||||||
|
Microsystems, Inc. aux Etats-Unis et dans d'autres pays.
|
||||||
|
|
||||||
|
Toutes les marques SPARC sont utilise'es sous licence et sont
|
||||||
|
des marques de fabrique ou des marques de'pose'es de SPARC
|
||||||
|
International, Inc. aux Etats-Unis et dans
|
||||||
|
d'autres pays. Les produits portant les marques SPARC sont
|
||||||
|
base's sur une architecture de'veloppe'e par Sun Microsystems, Inc.
|
||||||
|
|
||||||
|
Postcript est une marque enregistre'e d'Adobe Systems Inc.
|
||||||
|
|
||||||
|
LA DOCUMENTATION EST FOURNIE "EN L'ETAT" ET TOUTES AUTRES CONDITIONS,
|
||||||
|
DECLARATIONS ET GARANTIES EXPRESSES OU TACITES SONT FORMELLEMENT EXCLUES,
|
||||||
|
DANS LA MESURE AUTORISEE PAR LA LOI APPLICABLE, Y COMPRIS NOTAMMENT
|
||||||
|
TOUTE GARANTIE IMPLICITE RELATIVE A LA QUALITE MARCHANDE, A L'APTITUDE
|
||||||
|
A UNE UTILISATION PARTICULIERE OU A L'ABSENCE DE CONTREFACON.
|
||||||
|
-->
|
||||||
|
|
||||||
|
|
||||||
|
<!-- DTD for a Preferences tree. -->
|
||||||
|
|
||||||
|
<!-- The preferences element is at the root of an XML document
|
||||||
|
representing a Preferences tree. -->
|
||||||
|
<!ELEMENT preferences (root)>
|
||||||
|
|
||||||
|
<!-- The preferences element contains an optional version attribute,
|
||||||
|
which specifies version of DTD. -->
|
||||||
|
<!ATTLIST preferences EXTERNAL_XML_VERSION CDATA "0.0" >
|
||||||
|
|
||||||
|
<!-- The root element has a map representing the root's preferences
|
||||||
|
(if any), and one node for each child of the root (if any). -->
|
||||||
|
<!ELEMENT root (map, node*) >
|
||||||
|
|
||||||
|
<!-- Additionally, the root contains a type attribute, which
|
||||||
|
specifies whether it's the system or user root. -->
|
||||||
|
<!ATTLIST root
|
||||||
|
type (system|user) #REQUIRED >
|
||||||
|
|
||||||
|
<!-- Each node has a map representing its preferences (if any),
|
||||||
|
and one node for each child (if any). -->
|
||||||
|
<!ELEMENT node (map, node*) >
|
||||||
|
|
||||||
|
<!-- Additionally, each node has a name attribute -->
|
||||||
|
<!ATTLIST node
|
||||||
|
name CDATA #REQUIRED >
|
||||||
|
|
||||||
|
<!-- A map represents the preferences stored at a node (if any). -->
|
||||||
|
<!ELEMENT map (entry*) >
|
||||||
|
|
||||||
|
<!-- An entry represents a single preference, which is simply
|
||||||
|
a key-value pair. -->
|
||||||
|
<!ELEMENT entry EMPTY >
|
||||||
|
<!ATTLIST entry
|
||||||
|
key CDATA #REQUIRED
|
||||||
|
value CDATA #REQUIRED >
|
@ -0,0 +1,15 @@
|
|||||||
|
<!--
|
||||||
|
Copyright 2006 Sun Microsystems, Inc. All rights reserved.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!-- DTD for properties -->
|
||||||
|
|
||||||
|
<!ELEMENT properties ( comment?, entry* ) >
|
||||||
|
|
||||||
|
<!ATTLIST properties version CDATA #FIXED "1.0">
|
||||||
|
|
||||||
|
<!ELEMENT comment (#PCDATA) >
|
||||||
|
|
||||||
|
<!ELEMENT entry (#PCDATA) >
|
||||||
|
|
||||||
|
<!ATTLIST entry key CDATA #REQUIRED>
|
@ -402,6 +402,11 @@
|
|||||||
* @implNote
|
* @implNote
|
||||||
*
|
*
|
||||||
* <ul>
|
* <ul>
|
||||||
|
* <li><a href="#JDKCATALOG">JDK built-in Catalog</a>
|
||||||
|
* <ul>
|
||||||
|
* <li><a href="#JC_PROCESS">External Resource Resolution Process with the built-in Catalog</a></li>
|
||||||
|
* </ul>
|
||||||
|
* </li>
|
||||||
* <li><a href="#IN_ISFP">Implementation Specific Properties</a>
|
* <li><a href="#IN_ISFP">Implementation Specific Properties</a>
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li><a href="#Processor">Processor Support</a></li>
|
* <li><a href="#Processor">Processor Support</a></li>
|
||||||
@ -411,6 +416,33 @@
|
|||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
|
* <h2 id="JDKCATALOG">JDK built-in Catalog</h2>
|
||||||
|
* The JDK has a built-in catalog that hosts the following DTDs defined by the Java Platform:
|
||||||
|
* <ul>
|
||||||
|
* <li>DTD for {@link java.util.prefs.Preferences java.util.prefs.Preferences}, preferences.dtd</li>
|
||||||
|
* <li>DTD for {@link java.util.Properties java.util.Properties}, properties.dtd</li>
|
||||||
|
* </ul>
|
||||||
|
* <p>
|
||||||
|
* The catalog is loaded once when the first JAXP processor factory is created.
|
||||||
|
*
|
||||||
|
* <h3 id="JC_PROCESS">External Resource Resolution Process with the built-in Catalog</h3>
|
||||||
|
* The JDK creates a {@link javax.xml.catalog.CatalogResolver CatalogResolver}
|
||||||
|
* with the built-in catalog when needed. This CatalogResolver is used as the
|
||||||
|
* default external resource resolver.
|
||||||
|
* <p>
|
||||||
|
* XML processors may use resolvers (such as {@link org.xml.sax.EntityResolver EntityResolver},
|
||||||
|
* {@link javax.xml.stream.XMLResolver XMLResolver}, and {@link javax.xml.catalog.CatalogResolver CatalogResolver})
|
||||||
|
* to handle external references. In the absence of the user-defined resolvers,
|
||||||
|
* the JDK XML processors fall back to the default CatalogResolver to attempt to
|
||||||
|
* find a resolution before making a connection to fetch the resources. The fall-back
|
||||||
|
* also takes place if a user-defined resolver exists but allows the process to
|
||||||
|
* continue when unable to resolve the resource.
|
||||||
|
* <p>
|
||||||
|
* If the default CatalogResolver is unable to locate a resource, it may signal
|
||||||
|
* the XML processors to continue processing, or skip the resource, or
|
||||||
|
* throw a CatalogException. The behavior is configured with the
|
||||||
|
* <a href="#JDKCATALOG_RESOLVE">{@code jdk.xml.jdkcatalog.resolve}</a> property.
|
||||||
|
*
|
||||||
* <h2 id="IN_ISFP">Implementation Specific Properties</h2>
|
* <h2 id="IN_ISFP">Implementation Specific Properties</h2>
|
||||||
* In addition to the standard <a href="#Conf_Properties">JAXP Properties</a>,
|
* In addition to the standard <a href="#Conf_Properties">JAXP Properties</a>,
|
||||||
* the JDK implementation supports a number of implementation specific properties
|
* the JDK implementation supports a number of implementation specific properties
|
||||||
@ -752,7 +784,7 @@
|
|||||||
* <td id="ExtFunc">{@systemProperty jdk.xml.enableExtensionFunctions}</td>
|
* <td id="ExtFunc">{@systemProperty jdk.xml.enableExtensionFunctions}</td>
|
||||||
* <td>Determines if XSLT and XPath extension functions are to be allowed.
|
* <td>Determines if XSLT and XPath extension functions are to be allowed.
|
||||||
* </td>
|
* </td>
|
||||||
* <td style="text-align:center" rowspan="4">yes</td>
|
* <td style="text-align:center" rowspan="5">yes</td>
|
||||||
* <td style="text-align:center" rowspan="3">Boolean</td>
|
* <td style="text-align:center" rowspan="3">Boolean</td>
|
||||||
* <td>
|
* <td>
|
||||||
* true or false. True indicates that extension functions are allowed; False otherwise.
|
* true or false. True indicates that extension functions are allowed; False otherwise.
|
||||||
@ -842,6 +874,40 @@
|
|||||||
* <td style="text-align:center"><a href="#Processor">Method 1</a></td>
|
* <td style="text-align:center"><a href="#Processor">Method 1</a></td>
|
||||||
* <td style="text-align:center">22</td>
|
* <td style="text-align:center">22</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
|
* <tr>
|
||||||
|
* <td id="JDKCATALOG_RESOLVE">{@systemProperty jdk.xml.jdkcatalog.resolve}</td>
|
||||||
|
* <td>Instructs the JDK default CatalogResolver to act in accordance with the setting
|
||||||
|
* of this property when unable to resolve an external reference with the built-in Catalog.
|
||||||
|
* The options are:
|
||||||
|
* <ul>
|
||||||
|
* <li><p>
|
||||||
|
* {@code continue} -- Indicates that the processing should continue
|
||||||
|
* </li>
|
||||||
|
* <li><p>
|
||||||
|
* {@code ignore} -- Indicates that the reference is skipped
|
||||||
|
* </li>
|
||||||
|
* <li><p>
|
||||||
|
* {@code strict} -- Indicates that the resolver should throw a CatalogException
|
||||||
|
* </li>
|
||||||
|
* </ul>
|
||||||
|
* </td>
|
||||||
|
* <td style="text-align:center">String</td>
|
||||||
|
* <td>
|
||||||
|
* {@code continue, ignore, and strict}. Values are case-insensitive.
|
||||||
|
* </td>
|
||||||
|
* <td style="text-align:center">continue</td>
|
||||||
|
* <td style="text-align:center">No</td>
|
||||||
|
* <td style="text-align:center">Yes</td>
|
||||||
|
* <td style="text-align:center">
|
||||||
|
* <a href="#DOM">DOM</a><br>
|
||||||
|
* <a href="#SAX">SAX</a><br>
|
||||||
|
* <a href="#StAX">StAX</a><br>
|
||||||
|
* <a href="#Validation">Validation</a><br>
|
||||||
|
* <a href="#Transform">Transform</a>
|
||||||
|
* </td>
|
||||||
|
* <td style="text-align:center"><a href="#Processor">Method 1</a></td>
|
||||||
|
* <td style="text-align:center">22</td>
|
||||||
|
* </tr>
|
||||||
* </tbody>
|
* </tbody>
|
||||||
* </table>
|
* </table>
|
||||||
* <p id="Note1">
|
* <p id="Note1">
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -45,6 +45,7 @@ import java.util.StringJoiner;
|
|||||||
* This is a base class that every test class must extend if it needs to be run
|
* This is a base class that every test class must extend if it needs to be run
|
||||||
* with security mode.
|
* with security mode.
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
public class JAXPPolicyManager {
|
public class JAXPPolicyManager {
|
||||||
/*
|
/*
|
||||||
* Backing up policy.
|
* Backing up policy.
|
||||||
@ -161,6 +162,7 @@ public class JAXPPolicyManager {
|
|||||||
* Simple Policy class that supports the required Permissions to validate the
|
* Simple Policy class that supports the required Permissions to validate the
|
||||||
* JAXP concrete classes.
|
* JAXP concrete classes.
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
class TestPolicy extends Policy {
|
class TestPolicy extends Policy {
|
||||||
private final static Set<String> TEST_JARS =
|
private final static Set<String> TEST_JARS =
|
||||||
Set.of("jtreg.*jar", "javatest.*jar", "testng.*jar", "jcommander.*jar");
|
Set.of("jtreg.*jar", "javatest.*jar", "testng.*jar", "jcommander.*jar");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -371,7 +371,9 @@ public class CatalogSupportBase {
|
|||||||
if (setUseCatalog) {
|
if (setUseCatalog) {
|
||||||
factory.setFeature(XMLConstants.USE_CATALOG, useCatalog);
|
factory.setFeature(XMLConstants.USE_CATALOG, useCatalog);
|
||||||
}
|
}
|
||||||
|
if (catalog != null) {
|
||||||
factory.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
factory.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
||||||
|
}
|
||||||
|
|
||||||
Schema schema = factory.newSchema(new StreamSource(new StringReader(xsd)));
|
Schema schema = factory.newSchema(new StreamSource(new StringReader(xsd)));
|
||||||
success("XMLSchema.dtd and datatypes.dtd are resolved.");
|
success("XMLSchema.dtd and datatypes.dtd are resolved.");
|
||||||
@ -472,7 +474,9 @@ public class CatalogSupportBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
SAXParser parser = spf.newSAXParser();
|
SAXParser parser = spf.newSAXParser();
|
||||||
|
if (catalog != null) {
|
||||||
parser.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
parser.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
||||||
|
}
|
||||||
return parser;
|
return parser;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -495,7 +499,9 @@ public class CatalogSupportBase {
|
|||||||
if (setUseCatalog) {
|
if (setUseCatalog) {
|
||||||
reader.setFeature(XMLConstants.USE_CATALOG, useCatalog);
|
reader.setFeature(XMLConstants.USE_CATALOG, useCatalog);
|
||||||
}
|
}
|
||||||
|
if (catalog != null) {
|
||||||
reader.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
reader.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
||||||
|
}
|
||||||
return reader;
|
return reader;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -566,7 +572,9 @@ public class CatalogSupportBase {
|
|||||||
if (setUseCatalog) {
|
if (setUseCatalog) {
|
||||||
xif.setProperty(XMLConstants.USE_CATALOG, useCatalog);
|
xif.setProperty(XMLConstants.USE_CATALOG, useCatalog);
|
||||||
}
|
}
|
||||||
|
if (catalog != null) {
|
||||||
xif.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
xif.setProperty(CatalogFeatures.Feature.FILES.getPropertyName(), catalog);
|
||||||
|
}
|
||||||
ss = new StAXSource(xif.createXMLEventReader(
|
ss = new StAXSource(xif.createXMLEventReader(
|
||||||
xmlFileId, new FileInputStream(xmlFile)));
|
xmlFileId, new FileInputStream(xmlFile)));
|
||||||
} catch (Exception e) {}
|
} catch (Exception e) {}
|
||||||
@ -1013,6 +1021,7 @@ public class CatalogSupportBase {
|
|||||||
* Simple policy implementation that grants a set of permissions to all code
|
* Simple policy implementation that grants a set of permissions to all code
|
||||||
* sources and protection domains.
|
* sources and protection domains.
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("removal")
|
||||||
static class SimplePolicy extends Policy {
|
static class SimplePolicy extends Policy {
|
||||||
|
|
||||||
private final Permissions perms;
|
private final Permissions perms;
|
||||||
|
@ -0,0 +1,361 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
import common.util.TestBase;
|
||||||
|
import javax.xml.parsers.DocumentBuilderFactory;
|
||||||
|
import javax.xml.parsers.SAXParser;
|
||||||
|
import javax.xml.stream.XMLInputFactory;
|
||||||
|
import javax.xml.transform.TransformerFactory;
|
||||||
|
import javax.xml.validation.SchemaFactory;
|
||||||
|
//import org.testng.annotations.DataProvider;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests the JDK Catalog
|
||||||
|
*/
|
||||||
|
public class CatalogTestBase extends TestBase {
|
||||||
|
/*
|
||||||
|
* DataProvider for testing configuring properties for parsers.
|
||||||
|
*
|
||||||
|
* Fields:
|
||||||
|
* file, FSP, state of setting, config file, system property, api property,
|
||||||
|
* Custom Catalog, error expected, error code or expected result
|
||||||
|
*/
|
||||||
|
//@DataProvider(name = "configWCatalogForParsers")
|
||||||
|
public Object[][] getConfigs(Processor processor) {
|
||||||
|
// file with an external DTD that's not in JdkCatalog
|
||||||
|
String fileDTDNotInC = "properties1.xml";
|
||||||
|
// file with an external DTD that's in the Custom Catalog
|
||||||
|
String fileDTDInCC = "test.xml";
|
||||||
|
// file with an external DTD that's in JdkCatalog
|
||||||
|
String javaDTD = "properties.xml";
|
||||||
|
// file with an external DTD thats in the Custom Catalog
|
||||||
|
String w3cDTD = "xhtml11.xml";
|
||||||
|
|
||||||
|
// error code when CATALOG=strict; The cause for DOM
|
||||||
|
String errCode = "JAXP09040001";
|
||||||
|
|
||||||
|
// error (not from catalog) is expect when CATALOG=continue
|
||||||
|
boolean isErrExpected = true;
|
||||||
|
String expected1 = "invalid.site.com";
|
||||||
|
|
||||||
|
// expected when reference is resolved by Catalog
|
||||||
|
String expected3 = "", expected4 = "";
|
||||||
|
switch (processor) {
|
||||||
|
case SAX:
|
||||||
|
errCode = "JAXP00090001";
|
||||||
|
break;
|
||||||
|
case STAX:
|
||||||
|
errCode = "JAXP00090001";
|
||||||
|
//errCode = "JAXP00090001";
|
||||||
|
// StAX is non-validating parser
|
||||||
|
isErrExpected = false;
|
||||||
|
expected1 = ".*[\\w\\s]*(value1)[\\w\\s]*.*";
|
||||||
|
expected3 = "Minimal XHTML 1.1 DocumentThis is a minimal XHTML 1.1 document.";
|
||||||
|
expected4 = ".*(123)[\\w\\s]*.*";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Object[][]{
|
||||||
|
// Case 1: external reference not in the JDKCatalog
|
||||||
|
/**
|
||||||
|
* Case 1-1: default setting; no Config file; Catalog: continue (by default)
|
||||||
|
* Expect: error as the parser continues and tries to access an invalid site
|
||||||
|
* java.net.UnknownHostException: invalid.site.com
|
||||||
|
*/
|
||||||
|
{fileDTDNotInC, null, null, null, null, null, null, isErrExpected, expected1},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-2: set JDK Catalog to strict in a Config file
|
||||||
|
* Expect: Exception since the external reference is not in the Catalog
|
||||||
|
* Error Msg:
|
||||||
|
* [Fatal Error] properties1.xml:2:75: JAXP00090001: The CatalogResolver is enabled with the catalog "JdkCatalog.xml", but a CatalogException is returned.
|
||||||
|
* org.xml.sax.SAXException: javax.xml.catalog.CatalogException: JAXP09040001: No match found for publicId 'null' and systemId 'http://invalid.site.com/dtd/properties1.dtd'.
|
||||||
|
* javax.xml.catalog.CatalogException: JAXP09040001: No match found for publicId 'null' and systemId 'http://invalid.site.com/dtd/properties1.dtd'.
|
||||||
|
*/
|
||||||
|
{fileDTDNotInC, null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, null, true, errCode},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-3: set CATALOG back to continue through the System Property
|
||||||
|
* Expect: error as the parser continues and tries to access an invalid site
|
||||||
|
* java.net.UnknownHostException: invalid.site.com
|
||||||
|
*/
|
||||||
|
{fileDTDNotInC, null, PropertyState.CONFIG_FILE_SYSTEM, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, null, null, isErrExpected, expected1},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-4: override the settings in Case 3 with the API property, and set Catalog to strict
|
||||||
|
* Expect: Exception since the external reference is not in the Catalog
|
||||||
|
*/
|
||||||
|
{fileDTDNotInC, null, PropertyState.CONFIG_FILE_SYSTEM_API, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, new Properties[]{Properties.CATALOG2}, null, true, errCode},
|
||||||
|
|
||||||
|
// Case 2: external reference in the JDKCatalog
|
||||||
|
/**
|
||||||
|
* Case 2-1: set CATALOG to strict in a Config file
|
||||||
|
* Compare to: case 1-2
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{javaDTD, null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, null, false, expected1},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 2-2: override the settings in Case 3 with the API property, and set Catalog to strict
|
||||||
|
* Compare to: case 1-4
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{javaDTD, null, PropertyState.CONFIG_FILE_SYSTEM_API, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, new Properties[]{Properties.CATALOG2}, null, false, expected1},
|
||||||
|
|
||||||
|
// Case 3: external reference in the Custom Catalog
|
||||||
|
/**
|
||||||
|
* Case 3-1: set CATALOG to strict in a Config file
|
||||||
|
* Compare to: case 1-2, would have resulted in an error without the
|
||||||
|
* custom catalog
|
||||||
|
* Expect: pass without error because the external reference is in
|
||||||
|
* the custom catalog
|
||||||
|
*/
|
||||||
|
{fileDTDInCC, null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, CustomCatalog.STRICT, false, expected4},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 3-2: override the settings in Case 3 with the API property, and set Catalog to strict
|
||||||
|
* Compare to: case 1-4, would have resulted in an error without the
|
||||||
|
* custom catalog
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{fileDTDInCC, null, PropertyState.CONFIG_FILE_SYSTEM_API, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, new Properties[]{Properties.CATALOG2}, CustomCatalog.STRICT, false, expected4},
|
||||||
|
|
||||||
|
// Case 4: Parameter Entity reference
|
||||||
|
/**
|
||||||
|
* Case 4-1: set CATALOG to strict in a Config file
|
||||||
|
* Compare to: case 1-2, would have resulted in an error since the external
|
||||||
|
* reference can not be found
|
||||||
|
* Expect: pass without error because the external reference is in
|
||||||
|
* the custom catalog
|
||||||
|
*/
|
||||||
|
{"testExternalParameter.xml", null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, CustomCatalog.STRICT, false, expected1},
|
||||||
|
|
||||||
|
// Case 5: resolve xInclude with the Custom Catalog
|
||||||
|
/**
|
||||||
|
* Case 5-1: set CATALOG to strict in a Config file
|
||||||
|
* Compare to: case 1-2, would have resulted in an error without the
|
||||||
|
* custom catalog
|
||||||
|
* Expect: pass without error because the external reference is in
|
||||||
|
* the custom catalog
|
||||||
|
*/
|
||||||
|
{"XI_roottest.xml", null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, CustomCatalog.STRICT, false, ""},
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* DataProvider for testing configuring properties for validation or transform.
|
||||||
|
*
|
||||||
|
* Fields:
|
||||||
|
* xml file, xsd or xsl file, FSP, state of setting, config file, system property,
|
||||||
|
* api property, Custom Catalog, error expected, error code or expected result
|
||||||
|
*/
|
||||||
|
//@DataProvider(name = "validationOrTransform")
|
||||||
|
public Object[][] getConfig(String m) {
|
||||||
|
// Schema Import
|
||||||
|
String xmlFile = "XSDImport_company.xsd";
|
||||||
|
String xsdOrXsl = null;
|
||||||
|
String expected = "";
|
||||||
|
String errCode = "JAXP00090001";
|
||||||
|
|
||||||
|
switch (m) {
|
||||||
|
case "SchemaTest2":
|
||||||
|
// Schema Include
|
||||||
|
xmlFile = "XSDInclude_company.xsd";
|
||||||
|
break;
|
||||||
|
case "Validation":
|
||||||
|
// Schema Location
|
||||||
|
xmlFile = "val_test.xml";
|
||||||
|
break;
|
||||||
|
case "Stylesheet":
|
||||||
|
errCode = "JAXP09040001";
|
||||||
|
xmlFile = "XSLDTD.xsl";
|
||||||
|
break;
|
||||||
|
case "Transform":
|
||||||
|
xmlFile = "XSLPI.xml";
|
||||||
|
errCode = "JAXP09040001";
|
||||||
|
xsdOrXsl = "<?xml version='1.0'?>"
|
||||||
|
+ "<!DOCTYPE top SYSTEM 'test.dtd'"
|
||||||
|
+ "["
|
||||||
|
+ "<!ENTITY % pe \"x\">"
|
||||||
|
+ "<!ENTITY x1 \"AAAAA\">"
|
||||||
|
+ "<!ENTITY x2 \"bbb\">"
|
||||||
|
+"]>"
|
||||||
|
+ "<?xml-stylesheet href=\""
|
||||||
|
+ TEST_SOURCE_DIR
|
||||||
|
+ "/XSLPI_target.xsl\" type=\"text/xml\"?>"
|
||||||
|
+ "<xsl:stylesheet "
|
||||||
|
+ " xmlns:xsl='http://www.w3.org/1999/XSL/Transform' "
|
||||||
|
+ " version='1.0'>"
|
||||||
|
+ "</xsl:stylesheet> ";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Object[][]{
|
||||||
|
// Case 1: external reference not in the JDKCatalog
|
||||||
|
/**
|
||||||
|
* Case 1-1: default setting; no Config file; Catalog: continue
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{xmlFile, xsdOrXsl, null, null, null, null, null, null, false, expected},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-2: set CATALOG to strict in a Config file
|
||||||
|
* Expect: Exception since the external reference is not in the Catalog
|
||||||
|
* Sample Error Msg:
|
||||||
|
* org.xml.sax.SAXParseException; systemId: file:path/XSDImport_company.xsd;
|
||||||
|
* lineNumber: 10; columnNumber: 11;
|
||||||
|
* JAXP00090001: The CatalogResolver is enabled with the catalog "JdkCatalog.xml",
|
||||||
|
* but a CatalogException is returned.
|
||||||
|
*/
|
||||||
|
{xmlFile, xsdOrXsl, null, PropertyState.CONFIG_FILE, Properties.CONFIG_FILE_CATALOG_STRICT, null, null, null, true, errCode},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-3: set CATALOG back to continue through the System Property
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{xmlFile, xsdOrXsl, null, PropertyState.CONFIG_FILE_SYSTEM, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, null, null, false, expected},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-4: override the settings in Case 3 with the API property, and set Catalog to strict
|
||||||
|
* Expect: Exception since the external reference is not in the Catalog
|
||||||
|
*/
|
||||||
|
{xmlFile, xsdOrXsl, null, PropertyState.CONFIG_FILE_SYSTEM_API, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, new Properties[]{Properties.CATALOG2}, null, true, errCode},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Case 1-5: use Custom Catalog to resolve external references
|
||||||
|
* Expect: pass without error
|
||||||
|
*/
|
||||||
|
{xmlFile, xsdOrXsl, null, PropertyState.CONFIG_FILE_SYSTEM_API, Properties.CONFIG_FILE_CATALOG_STRICT, new Properties[]{Properties.CATALOG0}, new Properties[]{Properties.CATALOG2}, CustomCatalog.STRICT, false, expected},
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "configWCatalogForParsers", priority=0)
|
||||||
|
public void testDOM(String filename, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
DocumentBuilderFactory dbf = getDBF(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
process(filename, dbf, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "configWCatalogForParsers")
|
||||||
|
public void testSAX(String filename, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
SAXParser parser = getSAXParser(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
process(filename, parser, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "configWCatalogForParsers")
|
||||||
|
public void testStAX(String filename, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
XMLInputFactory xif = getXMLInputFactory(state, config, sysProp, apiProp, cc);
|
||||||
|
process(filename, xif, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "validationOrTransform")
|
||||||
|
public void testSchema1(String filename, String xsd, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
SchemaFactory sf = getSchemaFactory(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
process(filename, sf, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "validationOrTransform")
|
||||||
|
public void testSchema2(String filename, String xsd, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
testSchema1(filename, xsd, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "validationOrTransform")
|
||||||
|
public void testValidation(String filename, String xsd, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
SchemaFactory sf = getSchemaFactory(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
validate(filename, sf, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "validationOrTransform")
|
||||||
|
public void testStylesheet(String filename, String xsl, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
TransformerFactory tf = getTransformerFactory(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
process(filename, tf, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Test(dataProvider = "validationOrTransform")
|
||||||
|
public void testTransform(String filename, String xsl, Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc,
|
||||||
|
boolean expectError, String error) throws Exception {
|
||||||
|
|
||||||
|
TransformerFactory tf = getTransformerFactory(fsp, state, config, sysProp, apiProp, cc);
|
||||||
|
transform(filename, xsl, tf, expectError, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// parameters in the same order as the test method
|
||||||
|
String filename; String xsd; String xsl; Properties fsp; PropertyState state;
|
||||||
|
Properties config; Properties[] sysProp; Properties[] apiProp; CustomCatalog cc;
|
||||||
|
boolean expectError; String error;
|
||||||
|
|
||||||
|
// Maps the DataProvider array to individual parameters
|
||||||
|
public void paramMap(Processor processor, String method, String index) {
|
||||||
|
int i = 0;
|
||||||
|
Object[][] params;
|
||||||
|
if (processor == Processor.VALIDATOR ||
|
||||||
|
processor == Processor.TRANSFORMER) {
|
||||||
|
params = getConfig(method);
|
||||||
|
i = 1;
|
||||||
|
} else {
|
||||||
|
params = getConfigs(processor);
|
||||||
|
}
|
||||||
|
Object[] param = params[Integer.parseInt(index)];
|
||||||
|
filename = (String)param[0];
|
||||||
|
if (processor == Processor.VALIDATOR) {
|
||||||
|
xsd = (String)param[i];
|
||||||
|
} else if (processor == Processor.TRANSFORMER) {
|
||||||
|
xsl = (String)param[i];
|
||||||
|
}
|
||||||
|
fsp = (Properties)param[i + 1];
|
||||||
|
state = (PropertyState)param[i + 2];
|
||||||
|
config = (Properties)param[i + 3];
|
||||||
|
sysProp = (Properties[])param[i + 4];
|
||||||
|
apiProp = (Properties[])param[i + 5];
|
||||||
|
cc = (CustomCatalog)param[i + 6];
|
||||||
|
expectError = (boolean)param[i + 7];
|
||||||
|
error = (String)param[i + 8];
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test @bug 8306055
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @modules java.xml/jdk.xml.internal
|
||||||
|
* @run driver common.catalog.DOMTest 0 // verifies default setting catalog.resolve=allow
|
||||||
|
* @run driver common.catalog.DOMTest 1 // verifies overriding with catalog.resolve=strict in a config file
|
||||||
|
* @run driver common.catalog.DOMTest 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.DOMTest 3 // verifies overriding with factory setting (catalog.resolve=strict)
|
||||||
|
* @run driver common.catalog.DOMTest 4 // verifies external DTD resolution with the JDK Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.DOMTest 5 // verifies external DTD resolution with the JDK Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.DOMTest 6 // verifies external DTD resolution with a custom Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.DOMTest 7 // verifies external DTD resolution with a custom Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.DOMTest 8 // verifies external parameter are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.DOMTest 9 // verifies XInclude are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @summary verifies DOM's support of the JDK Catalog.
|
||||||
|
*/
|
||||||
|
public class DOMTest extends CatalogTestBase {
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
new DOMTest().run(args[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run(String index) throws Exception {
|
||||||
|
paramMap(Processor.DOM, null, index);
|
||||||
|
super.testDOM(filename, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test @bug 8306055
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @modules java.xml/jdk.xml.internal
|
||||||
|
* @run driver common.catalog.SAXTest 0 // verifies default setting catalog.resolve=allow
|
||||||
|
* @run driver common.catalog.SAXTest 1 // verifies overriding with catalog.resolve=strict in a config file
|
||||||
|
* @run driver common.catalog.SAXTest 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.SAXTest 3 // verifies overriding with factory setting (catalog.resolve=strict)
|
||||||
|
* @run driver common.catalog.SAXTest 4 // verifies external DTD resolution with the JDK Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.SAXTest 5 // verifies external DTD resolution with the JDK Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.SAXTest 6 // verifies external DTD resolution with a custom Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.SAXTest 7 // verifies external DTD resolution with a custom Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.SAXTest 8 // verifies external parameter are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.SAXTest 9 // verifies XInclude are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @summary verifies DOM's support of the JDK Catalog.
|
||||||
|
|
||||||
|
*/
|
||||||
|
public class SAXTest extends CatalogTestBase {
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
new SAXTest().run(args[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run(String index) throws Exception {
|
||||||
|
paramMap(Processor.SAX, null, index);
|
||||||
|
super.testSAX(filename, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test @bug 8306632
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @modules java.xml/jdk.xml.internal
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest1 0 // verifies default setting dtd.support=allow
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest1 1 // verifies overriding with config file
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest1 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest1 3 // verifies overriding with factory setting (DTD=deny)
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest1 4 // verifies DTD=ignore
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest2 0 // verifies default setting dtd.support=allow
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest2 1 // verifies overriding with config file
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest2 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest2 3 // verifies overriding with factory setting (DTD=deny)
|
||||||
|
* @run driver common.catalog.SchemaTest SchemaTest2 4 // verifies DTD=ignore
|
||||||
|
* @run driver common.catalog.SchemaTest Validation 0 // verifies default setting dtd.support=allow
|
||||||
|
* @run driver common.catalog.SchemaTest Validation 1 // verifies overriding with config file
|
||||||
|
* @run driver common.catalog.SchemaTest Validation 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.SchemaTest Validation 3 // verifies overriding with factory setting (DTD=deny)
|
||||||
|
* @run driver common.catalog.SchemaTest Validation 4 // verifies DTD=ignore
|
||||||
|
* @summary verifies Schema and Validation's support of the property jdk.xml.dtd.support.
|
||||||
|
*/
|
||||||
|
public class SchemaTest extends CatalogTestBase {
|
||||||
|
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
new SchemaTest().run(args[0], args[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run(String method, String index) throws Exception {
|
||||||
|
paramMap(Processor.VALIDATOR, method, index);
|
||||||
|
switch (method) {
|
||||||
|
case "SchemaTest1":
|
||||||
|
super.testSchema1(filename, xsd, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
break;
|
||||||
|
case "SchemaTest2":
|
||||||
|
super.testSchema2(filename, xsd, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
break;
|
||||||
|
case "Validation":
|
||||||
|
super.testValidation(filename, xsd, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test @bug 8306055
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @modules java.xml/jdk.xml.internal
|
||||||
|
* @run driver common.catalog.StAXTest 0 // verifies default setting catalog.resolve=allow
|
||||||
|
* @run driver common.catalog.StAXTest 1 // verifies overriding with catalog.resolve=strict in a config file
|
||||||
|
* @run driver common.catalog.StAXTest 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.StAXTest 3 // verifies overriding with factory setting (catalog.resolve=strict)
|
||||||
|
* @run driver common.catalog.StAXTest 4 // verifies external DTD resolution with the JDK Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.StAXTest 5 // verifies external DTD resolution with the JDK Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.StAXTest 6 // verifies external DTD resolution with a custom Catalog while resolve=strict in config file
|
||||||
|
* @run driver common.catalog.StAXTest 7 // verifies external DTD resolution with a custom Catalog while resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.StAXTest 8 // verifies external parameter are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @run driver common.catalog.StAXTest 9 // verifies XInclude are resolved with a custom Catalog though resolve=strict in API setting
|
||||||
|
* @summary verifies DOM's support of the JDK Catalog.
|
||||||
|
*/
|
||||||
|
public class StAXTest extends CatalogTestBase {
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
new StAXTest().run(args[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run(String index) throws Exception {
|
||||||
|
paramMap(Processor.STAX, null, index);
|
||||||
|
super.testStAX(filename, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,58 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
package common.catalog;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test @bug 8306632
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @modules java.xml/jdk.xml.internal
|
||||||
|
* @run driver common.catalog.TransformTest Stylesheet 0 // verifies default setting dtd.support=allow
|
||||||
|
* @run driver common.catalog.TransformTest Stylesheet 1 // verifies overriding with config file
|
||||||
|
* @run driver common.catalog.TransformTest Stylesheet 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.TransformTest Stylesheet 3 // verifies overriding with factory setting (DTD=deny)
|
||||||
|
* @run driver common.catalog.TransformTest Stylesheet 4 // verifies DTD=ignore
|
||||||
|
* @run driver common.catalog.TransformTest Transform 0 // verifies default setting dtd.support=allow
|
||||||
|
* @run driver common.catalog.TransformTest Transform 1 // verifies overriding with config file
|
||||||
|
* @run driver common.catalog.TransformTest Transform 2 // verifies overriding with system property
|
||||||
|
* @run driver common.catalog.TransformTest Transform 3 // verifies overriding with factory setting (DTD=deny)
|
||||||
|
* @run driver common.catalog.TransformTest Transform 4 // verifies DTD=ignore
|
||||||
|
* @summary verifies Transform's support of the property jdk.xml.dtd.support.
|
||||||
|
*/
|
||||||
|
public class TransformTest extends CatalogTestBase {
|
||||||
|
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
new TransformTest().run(args[0], args[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void run(String method, String index) throws Exception {
|
||||||
|
paramMap(Processor.TRANSFORMER, method, index);
|
||||||
|
switch (method) {
|
||||||
|
case "Stylesheet":
|
||||||
|
super.testStylesheet(filename, xsl, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
break;
|
||||||
|
case "Transform":
|
||||||
|
super.testTransform(filename, xsl, fsp, state, config, sysProp, apiProp, cc, expectError, error);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,32 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog">
|
||||||
|
<!-- Catalog for testing the CATALOG property
|
||||||
|
-->
|
||||||
|
|
||||||
|
<group id="dtds" prefer = "system" xml:base = "dtds/">
|
||||||
|
<systemSuffix systemIdSuffix="test.dtd" uri="test.dtd"/>
|
||||||
|
<system systemId="file:/externalParameterEntity" uri="paramEntity.dtd"/>
|
||||||
|
<system systemId="XSLDTD.dtd" uri="XSLDTD.dtd"/>
|
||||||
|
|
||||||
|
</group>
|
||||||
|
|
||||||
|
<group id="xsds" prefer = "system" xml:base = "xsds/">
|
||||||
|
<system systemId="XSDImport_person.xsd" uri="XSDImport_person.xsd"/>
|
||||||
|
<system systemId="XSDImport_product.xsd" uri="XSDImport_product.xsd"/>
|
||||||
|
<system systemId="XSDInclude_person.xsd" uri="XSDInclude_person.xsd"/>
|
||||||
|
<system systemId="XSDInclude_product.xsd" uri="XSDInclude_product.xsd"/>
|
||||||
|
<!-- file:/path/val_test.xsd -->
|
||||||
|
<systemSuffix systemIdSuffix="val_test.xsd" uri="val_test.xsd"/>
|
||||||
|
</group>
|
||||||
|
|
||||||
|
<group id="xi" prefer = "system" xml:base = "xinclude/">
|
||||||
|
|
||||||
|
<system systemId="XI_red.dtd" uri="XI_red.dtd"/>
|
||||||
|
<system systemId="XI_simple.xml" uri="XI_simple.xml"/>
|
||||||
|
<system systemId="XI_test2.xml" uri="XI_test2.xml"/>
|
||||||
|
<system systemId="XI_utf8.xml" uri="XI_utf8.xml"/>
|
||||||
|
</group>
|
||||||
|
<!-- additional catalogs can be added a NextCatalog besides registering
|
||||||
|
through the Feature.FILES (javax.xml.catalog.files) property -->
|
||||||
|
<!-- nextCatalog catalog="pathto/AnotherCatalog.xml"/-->
|
||||||
|
</catalog>
|
@ -0,0 +1,108 @@
|
|||||||
|
<?xml version="1.1" encoding="UTF-8"?>
|
||||||
|
<!-- Portions (C) International Organization for Standardization 1986
|
||||||
|
Permission to copy in any form is granted for use with
|
||||||
|
conforming SGML systems and applications as defined in
|
||||||
|
ISO 8879, provided this notice is included in all copies.
|
||||||
|
-->
|
||||||
|
<!-- Character entity set. Typical invocation:
|
||||||
|
<!ENTITY % HTMLlat1 PUBLIC
|
||||||
|
"-//W3C//ENTITIES Latin 1//EN//HTML">
|
||||||
|
%HTMLlat1;
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!ENTITY nbsp " " >
|
||||||
|
<!ENTITY iexcl "¡" >
|
||||||
|
<!ENTITY cent "¢" >
|
||||||
|
<!ENTITY pound "£" >
|
||||||
|
<!ENTITY curren "¤" >
|
||||||
|
<!ENTITY yen "¥" >
|
||||||
|
<!ENTITY brvbar "¦" >
|
||||||
|
<!ENTITY sect "§" >
|
||||||
|
<!ENTITY uml "¨" >
|
||||||
|
<!ENTITY copy "©" >
|
||||||
|
<!ENTITY ordf "ª" >
|
||||||
|
<!ENTITY laquo "«" >
|
||||||
|
<!ENTITY not "¬" >
|
||||||
|
<!ENTITY shy "­" >
|
||||||
|
<!ENTITY reg "®" >
|
||||||
|
<!ENTITY macr "¯" >
|
||||||
|
<!ENTITY deg "°" >
|
||||||
|
<!ENTITY plusmn "±" >
|
||||||
|
<!ENTITY sup2 "²" >
|
||||||
|
<!ENTITY sup3 "³" >
|
||||||
|
<!ENTITY acute "´" >
|
||||||
|
<!ENTITY micro "µ" >
|
||||||
|
<!ENTITY para "¶" >
|
||||||
|
<!ENTITY middot "·" >
|
||||||
|
<!ENTITY cedil "¸" >
|
||||||
|
<!ENTITY sup1 "¹" >
|
||||||
|
<!ENTITY ordm "º" >
|
||||||
|
<!ENTITY raquo "»" >
|
||||||
|
<!ENTITY frac14 "¼" >
|
||||||
|
<!ENTITY frac12 "½" >
|
||||||
|
<!ENTITY frac34 "¾" >
|
||||||
|
<!ENTITY iquest "¿" >
|
||||||
|
<!ENTITY Agrave "À" >
|
||||||
|
<!ENTITY Aacute "Á" >
|
||||||
|
<!ENTITY Acirc "Â" >
|
||||||
|
<!ENTITY Atilde "Ã" >
|
||||||
|
<!ENTITY Auml "Ä" >
|
||||||
|
<!ENTITY Aring "Å" >
|
||||||
|
<!ENTITY AElig "Æ" >
|
||||||
|
<!ENTITY Ccedil "Ç" >
|
||||||
|
<!ENTITY Egrave "È" >
|
||||||
|
<!ENTITY Eacute "É" >
|
||||||
|
<!ENTITY Ecirc "Ê" >
|
||||||
|
<!ENTITY Euml "Ë" >
|
||||||
|
<!ENTITY Igrave "Ì" >
|
||||||
|
<!ENTITY Iacute "Í" >
|
||||||
|
<!ENTITY Icirc "Î" >
|
||||||
|
<!ENTITY Iuml "Ï" >
|
||||||
|
<!ENTITY ETH "Ð" >
|
||||||
|
<!ENTITY Ntilde "Ñ" >
|
||||||
|
<!ENTITY Ograve "Ò" >
|
||||||
|
<!ENTITY Oacute "Ó" >
|
||||||
|
<!ENTITY Ocirc "Ô" >
|
||||||
|
<!ENTITY Otilde "Õ" >
|
||||||
|
<!ENTITY Ouml "Ö" >
|
||||||
|
<!ENTITY times "×" >
|
||||||
|
<!ENTITY Oslash "Ø" >
|
||||||
|
<!ENTITY Ugrave "Ù" >
|
||||||
|
<!ENTITY Uacute "Ú" >
|
||||||
|
<!ENTITY Ucirc "Û" >
|
||||||
|
<!ENTITY Uuml "Ü" >
|
||||||
|
<!ENTITY Yacute "Ý" >
|
||||||
|
<!ENTITY THORN "Þ" >
|
||||||
|
<!ENTITY szlig "ß" >
|
||||||
|
<!ENTITY agrave "à" >
|
||||||
|
<!ENTITY aacute "á" >
|
||||||
|
<!ENTITY acirc "â" >
|
||||||
|
<!ENTITY atilde "ã" >
|
||||||
|
<!ENTITY auml "ä" >
|
||||||
|
<!ENTITY aring "å" >
|
||||||
|
<!ENTITY aelig "æ" >
|
||||||
|
<!ENTITY ccedil "ç" >
|
||||||
|
<!ENTITY egrave "è" >
|
||||||
|
<!ENTITY eacute "é" >
|
||||||
|
<!ENTITY ecirc "ê" >
|
||||||
|
<!ENTITY euml "ë" >
|
||||||
|
<!ENTITY igrave "ì" >
|
||||||
|
<!ENTITY iacute "í" >
|
||||||
|
<!ENTITY icirc "î" >
|
||||||
|
<!ENTITY iuml "ï" >
|
||||||
|
<!ENTITY eth "ð" >
|
||||||
|
<!ENTITY ntilde "ñ" >
|
||||||
|
<!ENTITY ograve "ò" >
|
||||||
|
<!ENTITY oacute "ó" >
|
||||||
|
<!ENTITY ocirc "ô" >
|
||||||
|
<!ENTITY otilde "õ" >
|
||||||
|
<!ENTITY ouml "ö" >
|
||||||
|
<!ENTITY divide "÷" >
|
||||||
|
<!ENTITY oslash "ø" >
|
||||||
|
<!ENTITY ugrave "ù" >
|
||||||
|
<!ENTITY uacute "ú" >
|
||||||
|
<!ENTITY ucirc "û" >
|
||||||
|
<!ENTITY uuml "ü" >
|
||||||
|
<!ENTITY yacute "ý" >
|
||||||
|
<!ENTITY thorn "þ" >
|
||||||
|
<!ENTITY yuml "ÿ" >
|
@ -0,0 +1,2 @@
|
|||||||
|
<!ENTITY quantity "2">
|
||||||
|
<!ENTITY unitPrice "24.99">
|
@ -0,0 +1,6 @@
|
|||||||
|
|
||||||
|
<!ENTITY % bltin "*">
|
||||||
|
<!ENTITY % pe "x">
|
||||||
|
|
||||||
|
<!ELEMENT top (#PCDATA)>
|
||||||
|
|
@ -0,0 +1,4 @@
|
|||||||
|
<!--
|
||||||
|
Comment in DTD
|
||||||
|
|
||||||
|
-->
|
@ -0,0 +1,18 @@
|
|||||||
|
<simple>
|
||||||
|
<test xmlns:xinclude="http://www.w3.org/2001/XInclude">
|
||||||
|
<latin1>
|
||||||
|
<firstElement/>
|
||||||
|
<xinclude:include href="XI_utf8.xml" parse="text"/>
|
||||||
|
<insideChildren/>
|
||||||
|
<another>
|
||||||
|
<deeper>text</deeper>
|
||||||
|
</another>
|
||||||
|
</latin1>
|
||||||
|
<test2>
|
||||||
|
<xinclude:include href="XI_test2.xml"/>
|
||||||
|
</test2>
|
||||||
|
<test3>
|
||||||
|
<!-- <xinclude:include href="XI_roottest.xml"/> -->
|
||||||
|
</test3>
|
||||||
|
</test>
|
||||||
|
</simple>
|
@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<!-- comment before root -->
|
||||||
|
<!DOCTYPE red SYSTEM "XI_red.dtd">
|
||||||
|
<red xmlns:xinclude="http://www.w3.org/2001/XInclude">
|
||||||
|
<blue>
|
||||||
|
<xinclude:include href="XI_utf8.xml" parse="text"/>
|
||||||
|
</blue>
|
||||||
|
</red>
|
||||||
|
<!-- comment after root -->
|
||||||
|
|
@ -0,0 +1,4 @@
|
|||||||
|
<red>
|
||||||
|
value1 trjsagdkasgdhasdgashgdhsadgashdg
|
||||||
|
</red>
|
||||||
|
|
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||||
|
targetNamespace="http://www.person.org"
|
||||||
|
xmlns="http://www.person.org"
|
||||||
|
elementFormDefault="unqualified">
|
||||||
|
<xsd:complexType name="PersonType">
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="Name" type="xsd:string"/>
|
||||||
|
<xsd:element name="SSN" type="xsd:string"/>
|
||||||
|
</xsd:sequence>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:schema>
|
@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||||
|
targetNamespace="http://www.product.org"
|
||||||
|
xmlns="http://www.product.org"
|
||||||
|
elementFormDefault="unqualified">
|
||||||
|
<xsd:complexType name="ProductType">
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="Type" type="xsd:string"/>
|
||||||
|
</xsd:sequence>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:schema>
|
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||||
|
targetNamespace="http://www.company.org"
|
||||||
|
xmlns="http://www.person.org"
|
||||||
|
elementFormDefault="qualified">
|
||||||
|
<xsd:complexType name="PersonType">
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="Name" type="xsd:string"/>
|
||||||
|
<xsd:element name="SSN" type="xsd:string"/>
|
||||||
|
</xsd:sequence>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:schema>
|
@ -0,0 +1,11 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||||
|
targetNamespace="http://www.company.org"
|
||||||
|
xmlns="http://www.product.org"
|
||||||
|
elementFormDefault="qualified">
|
||||||
|
<xsd:complexType name="ProductType">
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="Type" type="xsd:string"/>
|
||||||
|
</xsd:sequence>
|
||||||
|
</xsd:complexType>
|
||||||
|
</xsd:schema>
|
@ -0,0 +1,16 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
|
||||||
|
targetNamespace="test">
|
||||||
|
<xsd:element name="root">
|
||||||
|
<xsd:complexType>
|
||||||
|
<xsd:sequence>
|
||||||
|
<xsd:element name="child" type="xsd:anyType"/>
|
||||||
|
</xsd:sequence>
|
||||||
|
</xsd:complexType>
|
||||||
|
|
||||||
|
<xsd:key name="key1">
|
||||||
|
<xsd:selector xpath="."/>
|
||||||
|
<xsd:field xpath="child"/>
|
||||||
|
</xsd:key>
|
||||||
|
</xsd:element>
|
||||||
|
</xsd:schema>
|
@ -0,0 +1,36 @@
|
|||||||
|
################################################################################
|
||||||
|
# XML Library (java.xml) Configuration File
|
||||||
|
#
|
||||||
|
# This file is in java.util.Properties format and typically located in the conf
|
||||||
|
# directory of the Java installation. It may contain key/value pairs for specifying
|
||||||
|
# the implementation class of a factory and/or properties that have corresponding
|
||||||
|
# system properties.
|
||||||
|
#
|
||||||
|
# This file can be replaced by specifying a filename with the java.xml.config.file
|
||||||
|
# system property. For example java -Djava.xml.config.file=myfile
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
# ---- Config File: for testing the CATALOG property ----
|
||||||
|
#
|
||||||
|
# strict: report error if not resolved by the JDK Catalog
|
||||||
|
jdk.xml.jdkCatalog.resolve=strict
|
||||||
|
# Enable Extension Functions
|
||||||
|
jdk.xml.enableExtensionFunctions=true
|
||||||
|
# Disallow overriding the default parser
|
||||||
|
jdk.xml.overrideDefaultParser=false
|
||||||
|
#
|
||||||
|
# Implementation specific limits:
|
||||||
|
#
|
||||||
|
jdk.xml.entityExpansionLimit=64000
|
||||||
|
jdk.xml.elementAttributeLimit=10000
|
||||||
|
jdk.xml.maxOccurLimit=5000
|
||||||
|
jdk.xml.totalEntitySizeLimit=100000
|
||||||
|
jdk.xml.maxGeneralEntitySizeLimit=0
|
||||||
|
jdk.xml.maxParameterEntitySizeLimit=1000000
|
||||||
|
jdk.xml.entityReplacementLimit=300000
|
||||||
|
jdk.xml.maxElementDepth=0
|
||||||
|
jdk.xml.maxXMLNameLimit=1000
|
||||||
|
jdk.xml.xpathExprGrpLimit=10
|
||||||
|
jdk.xml.xpathExprOpLimit=100
|
||||||
|
jdk.xml.xpathTotalOpLimit=10000
|
||||||
|
|
@ -128,6 +128,11 @@ jdk.xml.overrideDefaultParser=false
|
|||||||
#
|
#
|
||||||
# javax.xml.useCatalog=true
|
# javax.xml.useCatalog=true
|
||||||
#
|
#
|
||||||
|
# Implementation Specific Properties - DTD
|
||||||
|
#
|
||||||
|
# This property instructs the parsers to: deny, ignore or allow DTD processing.
|
||||||
|
# The following setting would cause the parser to reject DTD by throwing an exception.
|
||||||
|
# jdk.xml.dtd.support=deny
|
||||||
#
|
#
|
||||||
# Implementation Specific Properties - Limits
|
# Implementation Specific Properties - Limits
|
||||||
#
|
#
|
||||||
|
@ -17,15 +17,6 @@ import common.util.TestBase;
|
|||||||
* The DTD property controls how DTDs are processed.
|
* The DTD property controls how DTDs are processed.
|
||||||
*/
|
*/
|
||||||
public class DTDTestBase extends TestBase {
|
public class DTDTestBase extends TestBase {
|
||||||
static final String SRC_DIR;
|
|
||||||
static {
|
|
||||||
String srcDir = System.getProperty("test.src", ".");
|
|
||||||
if (IS_WINDOWS) {
|
|
||||||
srcDir = srcDir.replace('\\', '/');
|
|
||||||
}
|
|
||||||
SRC_DIR = srcDir;
|
|
||||||
TEST_SOURCE_DIR = srcDir + "/../xmlfiles/";
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testDOM(String filename, Properties fsp, PropertyState state,
|
public void testDOM(String filename, Properties fsp, PropertyState state,
|
||||||
Properties config, Properties[] sysProp, Properties[] apiProp,
|
Properties config, Properties[] sysProp, Properties[] apiProp,
|
||||||
|
@ -67,13 +67,31 @@ public class TestBase {
|
|||||||
ORACLE_JAXP_PROPERTY_PREFIX + "getEntityCountInfo";
|
ORACLE_JAXP_PROPERTY_PREFIX + "getEntityCountInfo";
|
||||||
public static final String CATALOG_FILE = CatalogFeatures.Feature.FILES.getPropertyName();
|
public static final String CATALOG_FILE = CatalogFeatures.Feature.FILES.getPropertyName();
|
||||||
public static final boolean IS_WINDOWS = System.getProperty("os.name").contains("Windows");
|
public static final boolean IS_WINDOWS = System.getProperty("os.name").contains("Windows");
|
||||||
public static String SRC_DIR = System.getProperty("test.src", ".");
|
public static String SRC_DIR;
|
||||||
public static String TEST_SOURCE_DIR;
|
public static String TEST_SOURCE_DIR, CONFIG_FILE_PATH, CATALOG_PATH;
|
||||||
|
|
||||||
|
static {
|
||||||
|
String srcDir = System.getProperty("test.src", ".");
|
||||||
|
if (IS_WINDOWS) {
|
||||||
|
srcDir = srcDir.replace('\\', '/');
|
||||||
|
}
|
||||||
|
SRC_DIR = srcDir;
|
||||||
|
if (IS_WINDOWS) {
|
||||||
|
CATALOG_PATH = "file:///" + SRC_DIR + "/../catalog/testcatalog/TestCatalog.xml";
|
||||||
|
} else {
|
||||||
|
CATALOG_PATH = "file://" + SRC_DIR + "/../catalog/testcatalog/TestCatalog.xml";
|
||||||
|
}
|
||||||
|
TEST_SOURCE_DIR = srcDir + "/../xmlfiles/";
|
||||||
|
CONFIG_FILE_PATH = SRC_DIR + "/../config/files/";
|
||||||
|
}
|
||||||
|
|
||||||
// configuration file system property
|
// configuration file system property
|
||||||
private static final String CONFIG_FILE = "java.xml.config.file";
|
private static final String CONFIG_FILE = "java.xml.config.file";
|
||||||
|
|
||||||
|
// CATALOG Abbreviation: C
|
||||||
|
static final String C_FILE = CatalogFeatures.Feature.FILES.getPropertyName();
|
||||||
|
static final String C_RESOLVE = CatalogFeatures.Feature.RESOLVE.getPropertyName();
|
||||||
|
|
||||||
// Xerces Property
|
// Xerces Property
|
||||||
public static final String DISALLOW_DTD = "http://apache.org/xml/features/disallow-doctype-decl";
|
public static final String DISALLOW_DTD = "http://apache.org/xml/features/disallow-doctype-decl";
|
||||||
public static final String LOAD_EXTERNAL_DTD = "http://apache.org/xml/features/nonvalidating/load-external-dtd";
|
public static final String LOAD_EXTERNAL_DTD = "http://apache.org/xml/features/nonvalidating/load-external-dtd";
|
||||||
@ -84,6 +102,7 @@ public class TestBase {
|
|||||||
|
|
||||||
// Impl Specific Properties
|
// Impl Specific Properties
|
||||||
public static final String SP_DTD = "jdk.xml.dtd.support";
|
public static final String SP_DTD = "jdk.xml.dtd.support";
|
||||||
|
public static final String SP_CATALOG = "jdk.xml.jdkCatalog.resolve";
|
||||||
public static final String OVERRIDE_PARSER = "jdk.xml.overrideDefaultParser";
|
public static final String OVERRIDE_PARSER = "jdk.xml.overrideDefaultParser";
|
||||||
|
|
||||||
// DTD/CATALOG constants
|
// DTD/CATALOG constants
|
||||||
@ -97,7 +116,10 @@ public class TestBase {
|
|||||||
|
|
||||||
// JAXP Configuration File(JCF) location
|
// JAXP Configuration File(JCF) location
|
||||||
// DTD = deny
|
// DTD = deny
|
||||||
public static final String JCF_DTD2 = "../config/files/dtd2.properties";
|
public static final String JCF_DTD2 = "dtd2.properties";
|
||||||
|
|
||||||
|
// CATALOG=strict
|
||||||
|
public static final String CONFIG_CATALOG_STRICT = "catalog2.properties";
|
||||||
|
|
||||||
|
|
||||||
String xmlExternalEntity, xmlExternalEntityId;
|
String xmlExternalEntity, xmlExternalEntityId;
|
||||||
@ -107,7 +129,9 @@ public class TestBase {
|
|||||||
static enum SourceType { STREAM, SAX, STAX, DOM };
|
static enum SourceType { STREAM, SAX, STAX, DOM };
|
||||||
|
|
||||||
public static enum Properties {
|
public static enum Properties {
|
||||||
CONFIG_FILE_DTD2(null, CONFIG_FILE, Type.FEATURE, getPath(JCF_DTD2)),
|
// config file: CATALOG = strict
|
||||||
|
CONFIG_FILE_CATALOG_STRICT(null, CONFIG_FILE, Type.FEATURE, getPath(CONFIG_FILE_PATH, CONFIG_CATALOG_STRICT)),
|
||||||
|
CONFIG_FILE_DTD2(null, CONFIG_FILE, Type.FEATURE, getPath(CONFIG_FILE_PATH, JCF_DTD2)),
|
||||||
FSP(XMLConstants.FEATURE_SECURE_PROCESSING, null, Type.FEATURE, "true"),
|
FSP(XMLConstants.FEATURE_SECURE_PROCESSING, null, Type.FEATURE, "true"),
|
||||||
FSP_FALSE(XMLConstants.FEATURE_SECURE_PROCESSING, null, Type.FEATURE, "false"),
|
FSP_FALSE(XMLConstants.FEATURE_SECURE_PROCESSING, null, Type.FEATURE, "false"),
|
||||||
|
|
||||||
@ -115,6 +139,9 @@ public class TestBase {
|
|||||||
DTD0(SP_DTD, "ditto", Type.PROPERTY, DTD_ALLOW),
|
DTD0(SP_DTD, "ditto", Type.PROPERTY, DTD_ALLOW),
|
||||||
DTD1(SP_DTD, "ditto", Type.PROPERTY, DTD_IGNORE),
|
DTD1(SP_DTD, "ditto", Type.PROPERTY, DTD_IGNORE),
|
||||||
DTD2(SP_DTD, "ditto", Type.PROPERTY, DTD_DENY),
|
DTD2(SP_DTD, "ditto", Type.PROPERTY, DTD_DENY),
|
||||||
|
CATALOG0(SP_CATALOG, "ditto", Type.PROPERTY, RESOLVE_CONTINUE),
|
||||||
|
CATALOG1(SP_CATALOG, "ditto", Type.PROPERTY, RESOLVE_IGNORE),
|
||||||
|
CATALOG2(SP_CATALOG, "ditto", Type.PROPERTY, RESOLVE_STRICT),
|
||||||
|
|
||||||
// StAX properties
|
// StAX properties
|
||||||
SUPPORT_DTD(XMLInputFactory.SUPPORT_DTD, null, Type.FEATURE, "true"),
|
SUPPORT_DTD(XMLInputFactory.SUPPORT_DTD, null, Type.FEATURE, "true"),
|
||||||
@ -181,11 +208,34 @@ public class TestBase {
|
|||||||
CONFIG_FILE_SYSTEM_API,
|
CONFIG_FILE_SYSTEM_API,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static enum CustomCatalog {
|
||||||
|
// continue processing if no match found
|
||||||
|
CONTINUE(CATALOG_PATH, "continue"),
|
||||||
|
// skip if no match found
|
||||||
|
IGNORE(CATALOG_PATH, "ignore"),
|
||||||
|
// throws CatalogException if no match found
|
||||||
|
STRICT(CATALOG_PATH, "strict");
|
||||||
|
|
||||||
|
String file, resolve;
|
||||||
|
CustomCatalog(String file, String resolve) {
|
||||||
|
this.file = file;
|
||||||
|
this.resolve = resolve;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String file() {
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String resolve() {
|
||||||
|
return resolve;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected void process(String filename, DocumentBuilderFactory dbf, boolean expectError,
|
protected void process(String filename, DocumentBuilderFactory dbf, boolean expectError,
|
||||||
String error) throws Exception {
|
String error) throws Exception {
|
||||||
//dbf.setAttribute(CatalogFeatures.Feature.RESOLVE.getPropertyName(), "continue");
|
//dbf.setAttribute(CatalogFeatures.Feature.RESOLVE.getPropertyName(), "continue");
|
||||||
DocumentBuilder builder = dbf.newDocumentBuilder();
|
DocumentBuilder builder = dbf.newDocumentBuilder();
|
||||||
File file = new File(getPath(filename));
|
File file = new File(getPath(TEST_SOURCE_DIR, filename));
|
||||||
try {
|
try {
|
||||||
Document document = builder.parse(file);
|
Document document = builder.parse(file);
|
||||||
Assert.assertTrue(!expectError);
|
Assert.assertTrue(!expectError);
|
||||||
@ -198,7 +248,7 @@ public class TestBase {
|
|||||||
protected void process(String filename, SAXParser parser, boolean expectError,
|
protected void process(String filename, SAXParser parser, boolean expectError,
|
||||||
String error) throws Exception {
|
String error) throws Exception {
|
||||||
|
|
||||||
File file = new File(getPath(filename));
|
File file = new File(getPath(TEST_SOURCE_DIR, filename));
|
||||||
try {
|
try {
|
||||||
parser.parse(file, new DefaultHandler());
|
parser.parse(file, new DefaultHandler());
|
||||||
Assert.assertTrue(!expectError);
|
Assert.assertTrue(!expectError);
|
||||||
@ -211,7 +261,7 @@ public class TestBase {
|
|||||||
protected void process(String filename, XMLInputFactory xif, boolean expectError,
|
protected void process(String filename, XMLInputFactory xif, boolean expectError,
|
||||||
String expected) throws Exception {
|
String expected) throws Exception {
|
||||||
|
|
||||||
String xml = getPath(filename);
|
String xml = getPath(TEST_SOURCE_DIR, filename);
|
||||||
try {
|
try {
|
||||||
InputStream entityxml = new FileInputStream(xml);
|
InputStream entityxml = new FileInputStream(xml);
|
||||||
XMLStreamReader streamReader = xif.createXMLStreamReader(xml, entityxml);
|
XMLStreamReader streamReader = xif.createXMLStreamReader(xml, entityxml);
|
||||||
@ -228,7 +278,7 @@ public class TestBase {
|
|||||||
protected void process(String filename, SchemaFactory sf, boolean expectError,
|
protected void process(String filename, SchemaFactory sf, boolean expectError,
|
||||||
String expected) throws Exception {
|
String expected) throws Exception {
|
||||||
|
|
||||||
String xsd = getPath(filename);
|
String xsd = getPath(TEST_SOURCE_DIR, filename);
|
||||||
try {
|
try {
|
||||||
Schema schema = sf.newSchema(new StreamSource(new File(xsd)));
|
Schema schema = sf.newSchema(new StreamSource(new File(xsd)));
|
||||||
Assert.assertTrue(!expectError);
|
Assert.assertTrue(!expectError);
|
||||||
@ -240,7 +290,7 @@ public class TestBase {
|
|||||||
|
|
||||||
protected void process(String filename, TransformerFactory tf, boolean expectError,
|
protected void process(String filename, TransformerFactory tf, boolean expectError,
|
||||||
String expected) throws Exception {
|
String expected) throws Exception {
|
||||||
String xsl = getPath(filename);
|
String xsl = getPath(TEST_SOURCE_DIR, filename);
|
||||||
try {
|
try {
|
||||||
SAXSource xslSource = new SAXSource(new InputSource(xsl));
|
SAXSource xslSource = new SAXSource(new InputSource(xsl));
|
||||||
xslSource.setSystemId(xsl);
|
xslSource.setSystemId(xsl);
|
||||||
@ -254,7 +304,7 @@ public class TestBase {
|
|||||||
|
|
||||||
protected void transform(String xmlFile, String xsl, TransformerFactory tf,
|
protected void transform(String xmlFile, String xsl, TransformerFactory tf,
|
||||||
boolean expectError, String expected) throws Exception {
|
boolean expectError, String expected) throws Exception {
|
||||||
String xmlSysId = getPath(xmlFile);
|
String xmlSysId = getPath(TEST_SOURCE_DIR, xmlFile);
|
||||||
try {
|
try {
|
||||||
SAXSource xslSource = new SAXSource(new InputSource(new StringReader(xsl)));
|
SAXSource xslSource = new SAXSource(new InputSource(new StringReader(xsl)));
|
||||||
//SAXSource xslSource = new SAXSource(new InputSource(xslSysId));
|
//SAXSource xslSource = new SAXSource(new InputSource(xslSysId));
|
||||||
@ -264,14 +314,13 @@ public class TestBase {
|
|||||||
transformer.transform(getSource(SourceType.STREAM, xmlSysId), new StreamResult(sw));
|
transformer.transform(getSource(SourceType.STREAM, xmlSysId), new StreamResult(sw));
|
||||||
Assert.assertTrue(!expectError);
|
Assert.assertTrue(!expectError);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
|
||||||
processError(expectError, expected, e);
|
processError(expectError, expected, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void validate(String filename, SchemaFactory sf, boolean expectError,
|
protected void validate(String filename, SchemaFactory sf, boolean expectError,
|
||||||
String expected) throws Exception {
|
String expected) throws Exception {
|
||||||
String xml = getPath(filename);
|
String xml = getPath(TEST_SOURCE_DIR, filename);
|
||||||
try {
|
try {
|
||||||
Schema schema = sf.newSchema();
|
Schema schema = sf.newSchema();
|
||||||
Validator validator = schema.newValidator();
|
Validator validator = schema.newValidator();
|
||||||
@ -309,6 +358,11 @@ public class TestBase {
|
|||||||
*/
|
*/
|
||||||
protected DocumentBuilderFactory getDBF(Properties fsp, PropertyState state,
|
protected DocumentBuilderFactory getDBF(Properties fsp, PropertyState state,
|
||||||
Properties config, Properties[] sysProp, Properties[] apiProp) {
|
Properties config, Properties[] sysProp, Properties[] apiProp) {
|
||||||
|
return getDBF(fsp, state, config, sysProp, apiProp, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected DocumentBuilderFactory getDBF(Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc) {
|
||||||
setSystemProperty(config, state, sysProp);
|
setSystemProperty(config, state, sysProp);
|
||||||
|
|
||||||
DocumentBuilderFactory dbf = DocumentBuilderFactory.newDefaultNSInstance();
|
DocumentBuilderFactory dbf = DocumentBuilderFactory.newDefaultNSInstance();
|
||||||
@ -335,6 +389,10 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (cc != null) {
|
||||||
|
dbf.setAttribute(C_FILE, cc.file());
|
||||||
|
dbf.setAttribute(C_RESOLVE, cc.resolve());
|
||||||
|
}
|
||||||
|
|
||||||
clearSystemProperty(state, sysProp);
|
clearSystemProperty(state, sysProp);
|
||||||
|
|
||||||
@ -355,6 +413,11 @@ public class TestBase {
|
|||||||
*/
|
*/
|
||||||
public SAXParser getSAXParser(Properties fsp, PropertyState state, Properties config,
|
public SAXParser getSAXParser(Properties fsp, PropertyState state, Properties config,
|
||||||
Properties[] sysProp, Properties[] apiProp) throws Exception {
|
Properties[] sysProp, Properties[] apiProp) throws Exception {
|
||||||
|
return getSAXParser(fsp, state, config, sysProp, apiProp, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SAXParser getSAXParser(Properties fsp, PropertyState state, Properties config,
|
||||||
|
Properties[] sysProp, Properties[] apiProp, CustomCatalog cc) throws Exception {
|
||||||
setSystemProperty(config, state, sysProp);
|
setSystemProperty(config, state, sysProp);
|
||||||
|
|
||||||
SAXParserFactory spf = SAXParserFactory.newDefaultNSInstance();
|
SAXParserFactory spf = SAXParserFactory.newDefaultNSInstance();
|
||||||
@ -387,12 +450,22 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cc != null) {
|
||||||
|
parser.setProperty(C_FILE, cc.file());
|
||||||
|
parser.setProperty(C_RESOLVE, cc.resolve());
|
||||||
|
}
|
||||||
|
|
||||||
clearSystemProperty(state, sysProp);
|
clearSystemProperty(state, sysProp);
|
||||||
return parser;
|
return parser;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected XMLInputFactory getXMLInputFactory(PropertyState state,
|
protected XMLInputFactory getXMLInputFactory(PropertyState state,
|
||||||
Properties config, Properties[] sysProp, Properties[] apiProp) {
|
Properties config, Properties[] sysProp, Properties[] apiProp) {
|
||||||
|
return getXMLInputFactory(state, config, sysProp, apiProp, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected XMLInputFactory getXMLInputFactory(PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc) {
|
||||||
setSystemProperty(config, state, sysProp);
|
setSystemProperty(config, state, sysProp);
|
||||||
XMLInputFactory factory = XMLInputFactory.newInstance();
|
XMLInputFactory factory = XMLInputFactory.newInstance();
|
||||||
|
|
||||||
@ -402,6 +475,11 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cc != null) {
|
||||||
|
factory.setProperty(C_FILE, cc.file());
|
||||||
|
factory.setProperty(C_RESOLVE, cc.resolve());
|
||||||
|
}
|
||||||
|
|
||||||
clearSystemProperty(state, sysProp);
|
clearSystemProperty(state, sysProp);
|
||||||
|
|
||||||
return factory;
|
return factory;
|
||||||
@ -410,6 +488,12 @@ public class TestBase {
|
|||||||
protected SchemaFactory getSchemaFactory(Properties fsp, PropertyState state,
|
protected SchemaFactory getSchemaFactory(Properties fsp, PropertyState state,
|
||||||
Properties config, Properties[] sysProp, Properties[] apiProp)
|
Properties config, Properties[] sysProp, Properties[] apiProp)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
|
return getSchemaFactory(fsp, state, config, sysProp, apiProp, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected SchemaFactory getSchemaFactory(Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc)
|
||||||
|
throws Exception {
|
||||||
setSystemProperty(config, state, sysProp);
|
setSystemProperty(config, state, sysProp);
|
||||||
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI);
|
||||||
|
|
||||||
@ -427,6 +511,11 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cc != null) {
|
||||||
|
factory.setProperty(C_FILE, cc.file());
|
||||||
|
factory.setProperty(C_RESOLVE, cc.resolve());
|
||||||
|
}
|
||||||
|
|
||||||
clearSystemProperty(state, sysProp);
|
clearSystemProperty(state, sysProp);
|
||||||
|
|
||||||
return factory;
|
return factory;
|
||||||
@ -435,6 +524,12 @@ public class TestBase {
|
|||||||
protected TransformerFactory getTransformerFactory(Properties fsp, PropertyState state,
|
protected TransformerFactory getTransformerFactory(Properties fsp, PropertyState state,
|
||||||
Properties config, Properties[] sysProp, Properties[] apiProp)
|
Properties config, Properties[] sysProp, Properties[] apiProp)
|
||||||
throws Exception {
|
throws Exception {
|
||||||
|
return getTransformerFactory(fsp, state, config, sysProp, apiProp, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected TransformerFactory getTransformerFactory(Properties fsp, PropertyState state,
|
||||||
|
Properties config, Properties[] sysProp, Properties[] apiProp, CustomCatalog cc)
|
||||||
|
throws Exception {
|
||||||
setSystemProperty(config, state, sysProp);
|
setSystemProperty(config, state, sysProp);
|
||||||
TransformerFactory tf = TransformerFactory.newInstance();
|
TransformerFactory tf = TransformerFactory.newInstance();
|
||||||
//tf.setAttribute(JDK_ENTITY_COUNT_INFO, "yes");
|
//tf.setAttribute(JDK_ENTITY_COUNT_INFO, "yes");
|
||||||
@ -450,6 +545,10 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (cc != null) {
|
||||||
|
tf.setAttribute(C_FILE, cc.file());
|
||||||
|
tf.setAttribute(C_RESOLVE, cc.resolve());
|
||||||
|
}
|
||||||
|
|
||||||
clearSystemProperty(state, sysProp);
|
clearSystemProperty(state, sysProp);
|
||||||
|
|
||||||
@ -605,8 +704,8 @@ public class TestBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static String getPath(String file) {
|
static String getPath(String base, String file) {
|
||||||
String temp = TEST_SOURCE_DIR + file;
|
String temp = base + file;
|
||||||
if (IS_WINDOWS) {
|
if (IS_WINDOWS) {
|
||||||
temp = "/" + temp;
|
temp = "/" + temp;
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.1"?>
|
||||||
|
<!-- comment before root 1 -->
|
||||||
|
<xinclude:include xmlns:xinclude="http://www.w3.org/2001/XInclude"
|
||||||
|
href="XI_simple.xml"/>
|
||||||
|
<!-- comment after root 1 -->
|
||||||
|
|
@ -0,0 +1,6 @@
|
|||||||
|
<!DOCTYPE top SYSTEM 'test.dtd'
|
||||||
|
[
|
||||||
|
<!ENTITY % pe0 "x">
|
||||||
|
<!ENTITY x1 "A">
|
||||||
|
]>
|
||||||
|
<top>123&x1;</top>
|
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version='1.0' encoding ='utf-8'?>
|
||||||
|
<!DOCTYPE SupplierOrder [
|
||||||
|
<!ENTITY % paraEntity SYSTEM "file:/externalParameterEntity">
|
||||||
|
%paraEntity;
|
||||||
|
]>
|
||||||
|
<SupplierOrder>
|
||||||
|
value value1
|
||||||
|
<OrderId>10016</OrderId>
|
||||||
|
<LineItems>
|
||||||
|
<LineItem categoryId="BIRDS" itemId="EST-18" lineNo="0" productId="AV-CB-01" quantity="&quantity;" unitPrice="&unitPrice;"/>
|
||||||
|
</LineItems>
|
||||||
|
</SupplierOrder>
|
Loading…
Reference in New Issue
Block a user