mirror of https://github.com/apache/poi.git
Use an error-handler to use logging also for XML parsing errors
Otherwise this output is done to stdout/stderr which we would like to avoid. Keep the format as one line and do not include a full exception stacktrace to not introduce lots of exception-stacktraces for some slightly broken input files git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1907108 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
0f290fe501
commit
bcd3785d7d
|
@ -47,6 +47,7 @@ import javax.xml.transform.TransformerFactory;
|
||||||
import javax.xml.validation.SchemaFactory;
|
import javax.xml.validation.SchemaFactory;
|
||||||
|
|
||||||
import org.apache.logging.log4j.Level;
|
import org.apache.logging.log4j.Level;
|
||||||
|
import org.apache.logging.log4j.LogBuilder;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.xml.sax.ErrorHandler;
|
import org.xml.sax.ErrorHandler;
|
||||||
|
@ -139,7 +140,7 @@ public final class XMLHelper {
|
||||||
try {
|
try {
|
||||||
DocumentBuilder documentBuilder = documentBuilderFactory.newDocumentBuilder();
|
DocumentBuilder documentBuilder = documentBuilderFactory.newDocumentBuilder();
|
||||||
documentBuilder.setEntityResolver(XMLHelper::ignoreEntity);
|
documentBuilder.setEntityResolver(XMLHelper::ignoreEntity);
|
||||||
documentBuilder.setErrorHandler(new DocHelperErrorHandler());
|
documentBuilder.setErrorHandler(new DocHelperErrorHandler(true));
|
||||||
return documentBuilder;
|
return documentBuilder;
|
||||||
} catch (ParserConfigurationException e) {
|
} catch (ParserConfigurationException e) {
|
||||||
throw new IllegalStateException("cannot create a DocumentBuilder", e);
|
throw new IllegalStateException("cannot create a DocumentBuilder", e);
|
||||||
|
@ -176,6 +177,7 @@ public final class XMLHelper {
|
||||||
public static XMLReader newXMLReader() throws SAXException, ParserConfigurationException {
|
public static XMLReader newXMLReader() throws SAXException, ParserConfigurationException {
|
||||||
XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();
|
XMLReader xmlReader = saxFactory.newSAXParser().getXMLReader();
|
||||||
xmlReader.setEntityResolver(XMLHelper::ignoreEntity);
|
xmlReader.setEntityResolver(XMLHelper::ignoreEntity);
|
||||||
|
xmlReader.setErrorHandler(new DocHelperErrorHandler(false));
|
||||||
trySet(xmlReader::setFeature, FEATURE_SECURE_PROCESSING, true);
|
trySet(xmlReader::setFeature, FEATURE_SECURE_PROCESSING, true);
|
||||||
trySet(xmlReader::setFeature, FEATURE_EXTERNAL_ENTITIES, false);
|
trySet(xmlReader::setFeature, FEATURE_EXTERNAL_ENTITIES, false);
|
||||||
Object manager = getXercesSecurityManager();
|
Object manager = getXercesSecurityManager();
|
||||||
|
@ -309,6 +311,11 @@ public final class XMLHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class DocHelperErrorHandler implements ErrorHandler {
|
private static class DocHelperErrorHandler implements ErrorHandler {
|
||||||
|
private final boolean logException;
|
||||||
|
|
||||||
|
public DocHelperErrorHandler(boolean logException) {
|
||||||
|
this.logException = logException;
|
||||||
|
}
|
||||||
|
|
||||||
public void warning(SAXParseException exception) {
|
public void warning(SAXParseException exception) {
|
||||||
printError(Level.WARN, exception);
|
printError(Level.WARN, exception);
|
||||||
|
@ -339,7 +346,13 @@ public final class XMLHelper {
|
||||||
':' + ex.getColumnNumber() +
|
':' + ex.getColumnNumber() +
|
||||||
':' + ex.getMessage();
|
':' + ex.getMessage();
|
||||||
|
|
||||||
LOG.atLevel(type).withThrowable(ex).log(message);
|
LogBuilder builder = LOG.atLevel(type);
|
||||||
|
|
||||||
|
if (logException) {
|
||||||
|
builder = builder.withThrowable(ex);
|
||||||
|
}
|
||||||
|
|
||||||
|
builder.log(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue