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:
Dominik Stadler 2023-01-30 12:19:37 +00:00
parent 0f290fe501
commit bcd3785d7d
1 changed files with 15 additions and 2 deletions

View File

@ -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);
} }
} }