public class DOMConfigurator extends Object implements org.apache.log4j.spi.Configurator
The DTD is specified in log4j.dtd.
Sometimes it is useful to see how log4j is reading configuration files. You can enable log4j internal logging by
defining the log4j.debug variable on the java command line. Alternatively, set the debug
attribute in the log4j:configuration element. As in
<log4j:configuration debug="true" xmlns:log4j="http://jakarta.apache.org/log4j/"> ... </log4j:configuration>
There are sample XML files included in the package.
| Modifier and Type | Field and Description |
|---|---|
protected org.apache.log4j.spi.LoggerFactory |
catFactory |
| Constructor and Description |
|---|
DOMConfigurator()
No argument constructor.
|
| Modifier and Type | Method and Description |
|---|---|
static void |
configure(Element element)
Configure log4j using a
configuration element as defined in the log4j.dtd. |
static void |
configure(String filename)
A static version of
doConfigure(String, LoggerRepository). |
static void |
configure(URL url)
A static version of
doConfigure(URL, LoggerRepository). |
static void |
configureAndWatch(String configFilename)
Like
configureAndWatch(String, long) except that the default delay as defined by
FileWatchdog.DEFAULT_DELAY is used. |
static void |
configureAndWatch(String configFilename,
long delay)
Read the configuration file
configFilename if it exists. |
void |
doConfigure(Element element,
org.apache.log4j.spi.LoggerRepository repository)
Configure by taking in an DOM element.
|
protected void |
doConfigure(InputSource inputSource,
org.apache.log4j.spi.LoggerRepository repository)
Configure log4j by reading in a log4j.dtd compliant XML configuration file.
|
void |
doConfigure(InputStream inputStream,
org.apache.log4j.spi.LoggerRepository repository)
Configure log4j by reading in a log4j.dtd compliant XML configuration file.
|
void |
doConfigure(Reader reader,
org.apache.log4j.spi.LoggerRepository repository)
Configure log4j by reading in a log4j.dtd compliant XML configuration file.
|
void |
doConfigure(String filename,
org.apache.log4j.spi.LoggerRepository repository) |
void |
doConfigure(URL url,
org.apache.log4j.spi.LoggerRepository repository) |
protected org.apache.log4j.Appender |
findAppenderByName(Document doc,
String appenderName)
Used internally to parse appenders by IDREF name.
|
protected org.apache.log4j.Appender |
findAppenderByReference(Element appenderRef)
Used internally to parse appenders by IDREF element.
|
protected void |
parse(Element element)
Used internally to configure the log4j framework by parsing a DOM tree of XML elements based on log4j.dtd.
|
protected org.apache.log4j.Appender |
parseAppender(Element appenderElement)
Used internally to parse an appender element.
|
protected void |
parseCategory(Element loggerElement)
Used internally to parse an category element.
|
protected void |
parseCategoryFactory(Element factoryElement)
Used internally to parse the category factory element.
|
protected void |
parseChildrenOfLoggerElement(Element catElement,
Logger cat,
boolean isRoot)
Used internally to parse the children of a category element.
|
static Object |
parseElement(Element element,
Properties props,
Class expectedClass)
Creates an object and processes any nested param elements but does not call activateOptions.
|
protected void |
parseErrorHandler(Element element,
org.apache.log4j.Appender appender)
Used internally to parse an
ErrorHandler element. |
protected void |
parseFilters(Element element,
org.apache.log4j.Appender appender)
Used internally to parse a filter element.
|
protected org.apache.log4j.Layout |
parseLayout(Element layout_element)
Used internally to parse a layout element.
|
protected void |
parseLevel(Element element,
Logger logger,
boolean isRoot)
Used internally to parse a level element.
|
protected void |
parseRenderer(Element element) |
protected void |
parseRoot(Element rootElement)
Used internally to parse the roor category element.
|
protected org.apache.log4j.spi.ThrowableRenderer |
parseThrowableRenderer(Element element)
Parses throwable renderer.
|
protected void |
setParameter(Element elem,
org.apache.log4j.config.PropertySetter propSetter) |
static void |
setParameter(Element elem,
org.apache.log4j.config.PropertySetter propSetter,
Properties props)
Sets a parameter based from configuration file content.
|
protected String |
subst(String value) |
static String |
subst(String value,
Properties props)
Substitutes property value for any references in expression.
|
protected org.apache.log4j.Appender findAppenderByName(Document doc, String appenderName)
protected org.apache.log4j.Appender findAppenderByReference(Element appenderRef)
protected org.apache.log4j.Appender parseAppender(Element appenderElement)
protected void parseErrorHandler(Element element, org.apache.log4j.Appender appender)
ErrorHandler element.protected void parseFilters(Element element, org.apache.log4j.Appender appender)
protected void parseCategory(Element loggerElement)
protected void parseCategoryFactory(Element factoryElement)
protected void parseRoot(Element rootElement)
protected void parseChildrenOfLoggerElement(Element catElement, Logger cat, boolean isRoot)
protected org.apache.log4j.Layout parseLayout(Element layout_element)
protected void parseRenderer(Element element)
protected org.apache.log4j.spi.ThrowableRenderer parseThrowableRenderer(Element element)
element - throwableRenderer element.protected void parseLevel(Element element, Logger logger, boolean isRoot)
protected void setParameter(Element elem, org.apache.log4j.config.PropertySetter propSetter)
public static void configure(Element element)
configuration element as defined in the log4j.dtd.public static void configureAndWatch(String configFilename)
configureAndWatch(String, long) except that the default delay as defined by
FileWatchdog.DEFAULT_DELAY is used.configFilename - A log4j configuration file in XML format.public static void configureAndWatch(String configFilename, long delay)
configFilename if it exists. Moreover, a thread will be created that
will periodically check if
configFilename has been created or modified. The period is
determined by the delay argument. If a change or file creation is detected, then
configFilename is read to configure log4j.configFilename - A log4j configuration file in XML format.delay - The delay in milliseconds to wait between each check.public void doConfigure(String filename, org.apache.log4j.spi.LoggerRepository repository)
public void doConfigure(URL url, org.apache.log4j.spi.LoggerRepository repository)
doConfigure in interface org.apache.log4j.spi.Configuratorpublic void doConfigure(InputStream inputStream, org.apache.log4j.spi.LoggerRepository repository) throws FactoryConfigurationError
doConfigure in interface org.apache.log4j.spi.ConfiguratorFactoryConfigurationErrorpublic void doConfigure(Reader reader, org.apache.log4j.spi.LoggerRepository repository) throws FactoryConfigurationError
FactoryConfigurationErrorprotected void doConfigure(InputSource inputSource, org.apache.log4j.spi.LoggerRepository repository) throws FactoryConfigurationError
FactoryConfigurationErrorpublic void doConfigure(Element element, org.apache.log4j.spi.LoggerRepository repository)
public static void configure(String filename) throws FactoryConfigurationError
doConfigure(String, LoggerRepository).FactoryConfigurationErrorpublic static void configure(URL url) throws FactoryConfigurationError
doConfigure(URL, LoggerRepository).FactoryConfigurationErrorprotected void parse(Element element)
public static String subst(String value, Properties props)
value - value from configuration file, may contain literal text, property references or bothprops - properties.public static void setParameter(Element elem, org.apache.log4j.config.PropertySetter propSetter, Properties props)
elem - param element, may not be null.propSetter - property setter, may not be null.props - propertiespublic static Object parseElement(Element element, Properties props, Class expectedClass) throws Exception
element - element, may not be null.props - propertiesexpectedClass - interface or class expected to be implemented by created classException - thrown if the contain object should be abandoned.Copyright © 2006–2023 OPS4J - Open Participation Software for Java. All rights reserved.