Class AbstractAccessLogValve
- java.lang.Object
- 
- org.apache.catalina.util.LifecycleBase
- 
- org.apache.catalina.util.LifecycleMBeanBase
- 
- org.apache.catalina.valves.ValveBase
- 
- org.apache.catalina.valves.AbstractAccessLogValve
 
 
 
 
- 
- All Implemented Interfaces:
- javax.management.MBeanRegistration,- AccessLog,- Contained,- JmxEnabled,- Lifecycle,- Valve
 - Direct Known Subclasses:
- AccessLogValve
 
 public abstract class AbstractAccessLogValve extends ValveBase implements AccessLog Abstract implementation of the Valve interface that generates a web server access log with the detailed line contents matching a configurable pattern. The syntax of the available patterns is similar to that supported by the Apache HTTP Server mod_log_configmodule.Patterns for the logged message may include constant text or any of the following replacement strings, for which the corresponding information from the specified Response is substituted: - %a- Remote IP address
- %A- Local IP address
- %b- Bytes sent, excluding HTTP headers, or '-' if no bytes were sent
- %B- Bytes sent, excluding HTTP headers
- %h- Remote host name (or IP address if- enableLookupsfor the connector is false)
- %H- Request protocol
- %l- Remote logical username from identd (always returns '-')
- %m- Request method
- %p- Local port
- %q- Query string (prepended with a '?' if it exists, otherwise an empty string
- %r- First line of the request
- %s- HTTP status code of the response
- %S- User session ID
- %t- Date and time, in Common Log Format format
- %u- Remote user that was authenticated
- %U- Requested URL path
- %v- Local server name
- %D- Time taken to process the request, in microseconds
- %T- Time taken to process the request, in seconds
- %F- Time taken to commit the response, in milliseconds
- %I- current Request thread name (can compare later with stacktraces)
- %X- Connection status when response is completed:- X= Connection aborted before the response completed.
- += Connection may be kept alive after the response is sent.
- -= Connection will be closed after the response is sent.
 
 In addition, the caller can specify one of the following aliases for commonly utilized patterns: - common - %h %l %u %t "%r" %s %b
- combined -
   %h %l %u %t "%r" %s %b "%{Referer}i" "%{User-Agent}i"
 There is also support to write information from the cookie, incoming header, the Session or something else in the ServletRequest. 
 It is modeled after the Apache HTTP Server log configuration syntax:- %{xxx}ifor incoming headers
- %{xxx}ofor outgoing response headers
- %{xxx}cfor a specific cookie
- %{xxx}rxxx is an attribute in the ServletRequest
- %{xxx}sxxx is an attribute in the HttpSession
- %{xxx}txxx is an enhanced SimpleDateFormat pattern (see Configuration Reference document for details on supported time patterns)
- %{xxx}Txxx is the unit for the time taken to process the request (see Configuration Reference document for details on supported units)
 Conditional logging is also supported. This can be done with the conditionUnlessandconditionIfproperties. If the value returned from ServletRequest.getAttribute(conditionUnless) yields a non-null value, the logging will be skipped. If the value returned from ServletRequest.getAttribute(conditionIf) yields the null value, the logging will be skipped. Theconditionattribute is synonym forconditionUnlessand is provided for backwards compatibility.For extended attributes coming from a getAttribute() call, it is you responsibility to ensure there are no newline or control characters. - Author:
- Craig R. McClanahan, Jason Brittain, Remy Maucherat, Takayuki Kaneko, Peter Rossbach
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static interfaceAbstractAccessLogValve.AccessLogElementAccessLogElement writes the partial message into the buffer.protected static classAbstractAccessLogValve.ByteSentElementwrite bytes sent, excluding HTTP headers - %b, %Bprotected static interfaceAbstractAccessLogValve.CachedElementMarks an AccessLogElement as needing to be have the value cached at the start of the request rather than just recorded at the end as the source data for the element may not be available at the end of the request.protected static classAbstractAccessLogValve.ConnectionStatusElementWrite connection status when response is completed - %Xprotected static classAbstractAccessLogValve.CookieElementwrite a specific cookie - %{xxx}cprotected classAbstractAccessLogValve.DateAndTimeElementwrite date and time, in configurable format (default CLF) - %t or %{format}tprotected static classAbstractAccessLogValve.DateFormatCacheCache structure for formatted timestamps based on seconds.protected static classAbstractAccessLogValve.ElapsedTimeElementwrite time taken to process the request - %D, %Tprotected static classAbstractAccessLogValve.FirstByteTimeElementwrite time until first byte is written (commit time) in millis - %Fprotected static classAbstractAccessLogValve.HeaderElementwrite incoming headers - %{xxx}iprotected classAbstractAccessLogValve.HostElementwrite remote host name - %hprotected static classAbstractAccessLogValve.HttpStatusCodeElementwrite HTTP status code of the response - %sprotected static classAbstractAccessLogValve.LocalAddrElementwrite local IP address - %Aprotected classAbstractAccessLogValve.LocalServerNameElementwrite local server name - %vprotected static classAbstractAccessLogValve.LogicalUserNameElementwrite remote logical username from identd (always returns '-') - %lprotected static classAbstractAccessLogValve.MethodElementwrite request method (GET, POST, etc.) - %mprotected classAbstractAccessLogValve.PortElementwrite local or remote port for request connection - %p and %{xxx}pprotected classAbstractAccessLogValve.ProtocolElementwrite request protocol - %Hprotected static classAbstractAccessLogValve.QueryElementwrite Query string (prepended with a '?'protected classAbstractAccessLogValve.RemoteAddrElementwrite remote IP address - %aprotected static classAbstractAccessLogValve.RequestAttributeElementwrite an attribute in the ServletRequest - %{xxx}rprotected static classAbstractAccessLogValve.RequestElementwrite first line of the request (method and request URI) - %rprotected static classAbstractAccessLogValve.RequestURIElementwrite requested URL path - %Uprotected static classAbstractAccessLogValve.ResponseHeaderElementwrite a specific response header - %{xxx}oprotected static classAbstractAccessLogValve.SessionAttributeElementwrite an attribute in the HttpSession - %{xxx}sprotected static classAbstractAccessLogValve.SessionIdElementwrite user session ID - %Sprotected static classAbstractAccessLogValve.StringElementwrite any stringprotected static classAbstractAccessLogValve.ThreadNameElementwrite thread name - %Iprotected static classAbstractAccessLogValve.UserElementwrite remote user that was authenticated (if any), else '-' - %u- 
Nested classes/interfaces inherited from interface org.apache.catalina.LifecycleLifecycle.SingleUse
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected AbstractAccessLogValve.CachedElement[]cachedElementsArray of elements where the value needs to be cached at the start of the request.protected java.lang.StringconditionAre we doing conditional logging. default null.protected java.lang.StringconditionIfAre we doing conditional logging. default null.protected booleanenabledenabled this componentprotected java.util.LocalelocaleLocale used to format timestamps in log entries and in log file name suffix.protected java.lang.StringlocaleNameName of locale used to format timestamps in log entries and in log file name suffix.protected AbstractAccessLogValve.AccessLogElement[]logElementsArray of AccessLogElement, they will be used to make log message.protected java.lang.StringpatternThe pattern used to format our access log lines.protected booleanrequestAttributesEnabledShould this valve use request attributes for IP address, hostname, protocol and port used for the request.- 
Fields inherited from class org.apache.catalina.valves.ValveBaseasyncSupported, container, containerLog, next, sm
 - 
Fields inherited from interface org.apache.catalina.AccessLogPROTOCOL_ATTRIBUTE, REMOTE_ADDR_ATTRIBUTE, REMOTE_HOST_ATTRIBUTE, SERVER_NAME_ATTRIBUTE, SERVER_PORT_ATTRIBUTE
 - 
Fields inherited from interface org.apache.catalina.LifecycleAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT
 
- 
 - 
Constructor SummaryConstructors Constructor Description AbstractAccessLogValve()
 - 
Method SummaryAll Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected AbstractAccessLogValve.AccessLogElementcreateAccessLogElement(char pattern)Create an AccessLogElement implementation.protected AbstractAccessLogValve.AccessLogElementcreateAccessLogElement(java.lang.String name, char pattern)Create an AccessLogElement implementation which needs an element name.protected AbstractAccessLogValve.AccessLogElement[]createLogElements()Parse pattern string and create the array of AccessLogElement.protected static voidescapeAndAppend(java.lang.String input, java.io.CharArrayWriter dest)protected static java.util.LocalefindLocale(java.lang.String name, java.util.Locale fallback)Find a locale by name.java.lang.StringgetCondition()Return whether the attribute name to look for when performing conditional logging.java.lang.StringgetConditionIf()Return whether the attribute name to look for when performing conditional logging.java.lang.StringgetConditionUnless()Return whether the attribute name to look for when performing conditional logging.booleangetEnabled()booleangetIpv6Canonical()java.lang.StringgetLocale()Return the locale used to format timestamps in log entries and in log file name suffix.intgetMaxLogMessageBufferSize()java.lang.StringgetPattern()booleangetRequestAttributesEnabled()voidinvoke(Request request, Response response)Log a message summarizing the specified request and response, according to the format specified by thepatternproperty.protected abstract voidlog(java.io.CharArrayWriter message)Log the specified message.voidlog(Request request, Response response, long time)Add the request/response to the access log using the specified processing time.voidsetCondition(java.lang.String condition)Set the ServletRequest.attribute to look for to perform conditional logging.voidsetConditionIf(java.lang.String condition)Set the ServletRequest.attribute to look for to perform conditional logging.voidsetConditionUnless(java.lang.String condition)Set the ServletRequest.attribute to look for to perform conditional logging.voidsetEnabled(boolean enabled)voidsetIpv6Canonical(boolean ipv6Canonical)voidsetLocale(java.lang.String localeName)Set the locale used to format timestamps in log entries and in log file name suffix.voidsetMaxLogMessageBufferSize(int maxLogMessageBufferSize)voidsetPattern(java.lang.String pattern)Set the format pattern, first translating any recognized alias.voidsetRequestAttributesEnabled(boolean requestAttributesEnabled)Should this valve use request attributes for IP address, hostname, protocol and port used for the request?protected voidstartInternal()Start this component and implement the requirements ofLifecycleBase.startInternal().protected voidstopInternal()Stop this component and implement the requirements ofLifecycleBase.stopInternal().- 
Methods inherited from class org.apache.catalina.valves.ValveBasebackgroundProcess, getContainer, getDomainInternal, getNext, getObjectNameKeyProperties, initInternal, isAsyncSupported, setAsyncSupported, setContainer, setNext, toString
 - 
Methods inherited from class org.apache.catalina.util.LifecycleMBeanBasedestroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister, unregister
 - 
Methods inherited from class org.apache.catalina.util.LifecycleBaseaddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stop
 
- 
 
- 
- 
- 
Field Detail- 
enabledprotected boolean enabled enabled this component
 - 
patternprotected java.lang.String pattern The pattern used to format our access log lines.
 - 
conditionprotected java.lang.String condition Are we doing conditional logging. default null. It is the value ofconditionUnlessproperty.
 - 
conditionIfprotected java.lang.String conditionIf Are we doing conditional logging. default null. It is the value ofconditionIfproperty.
 - 
localeNameprotected java.lang.String localeName Name of locale used to format timestamps in log entries and in log file name suffix.
 - 
localeprotected java.util.Locale locale Locale used to format timestamps in log entries and in log file name suffix.
 - 
logElementsprotected AbstractAccessLogValve.AccessLogElement[] logElements Array of AccessLogElement, they will be used to make log message.
 - 
cachedElementsprotected AbstractAccessLogValve.CachedElement[] cachedElements Array of elements where the value needs to be cached at the start of the request.
 - 
requestAttributesEnabledprotected boolean requestAttributesEnabled Should this valve use request attributes for IP address, hostname, protocol and port used for the request. Default isfalse.- See Also:
- setRequestAttributesEnabled(boolean)
 
 
- 
 - 
Method Detail- 
getMaxLogMessageBufferSizepublic int getMaxLogMessageBufferSize() 
 - 
setMaxLogMessageBufferSizepublic void setMaxLogMessageBufferSize(int maxLogMessageBufferSize) 
 - 
getIpv6Canonicalpublic boolean getIpv6Canonical() 
 - 
setIpv6Canonicalpublic void setIpv6Canonical(boolean ipv6Canonical) 
 - 
setRequestAttributesEnabledpublic void setRequestAttributesEnabled(boolean requestAttributesEnabled) Should this valve use request attributes for IP address, hostname, protocol and port used for the request? The attributes used are:- org.apache.catalina.RemoteAddr
- org.apache.catalina.RemoteHost
- org.apache.catalina.Protocol
- org.apache.catalina.ServerName
- org.apache.catalina.ServerPost
 false.- Specified by:
- setRequestAttributesEnabledin interface- AccessLog
- Parameters:
- requestAttributesEnabled-- truecauses the attributes to be used,- falsecauses the original values to be used.
 
 - 
getRequestAttributesEnabledpublic boolean getRequestAttributesEnabled() - Specified by:
- getRequestAttributesEnabledin interface- AccessLog
- Returns:
- trueif the attributes will be logged, otherwise- false
- See Also:
- AccessLog.setRequestAttributesEnabled(boolean)
 
 - 
getEnabledpublic boolean getEnabled() - Returns:
- the enabled flag.
 
 - 
setEnabledpublic void setEnabled(boolean enabled) - Parameters:
- enabled- The enabled to set.
 
 - 
getPatternpublic java.lang.String getPattern() - Returns:
- the format pattern.
 
 - 
setPatternpublic void setPattern(java.lang.String pattern) Set the format pattern, first translating any recognized alias.- Parameters:
- pattern- The new pattern
 
 - 
getConditionpublic java.lang.String getCondition() Return whether the attribute name to look for when performing conditional logging. If null, every request is logged.- Returns:
- the attribute name
 
 - 
setConditionpublic void setCondition(java.lang.String condition) Set the ServletRequest.attribute to look for to perform conditional logging. Set to null to log everything.- Parameters:
- condition- Set to null to log everything
 
 - 
getConditionUnlesspublic java.lang.String getConditionUnless() Return whether the attribute name to look for when performing conditional logging. If null, every request is logged.- Returns:
- the attribute name
 
 - 
setConditionUnlesspublic void setConditionUnless(java.lang.String condition) Set the ServletRequest.attribute to look for to perform conditional logging. Set to null to log everything.- Parameters:
- condition- Set to null to log everything
 
 - 
getConditionIfpublic java.lang.String getConditionIf() Return whether the attribute name to look for when performing conditional logging. If null, every request is logged.- Returns:
- the attribute name
 
 - 
setConditionIfpublic void setConditionIf(java.lang.String condition) Set the ServletRequest.attribute to look for to perform conditional logging. Set to null to log everything.- Parameters:
- condition- Set to null to log everything
 
 - 
getLocalepublic java.lang.String getLocale() Return the locale used to format timestamps in log entries and in log file name suffix.- Returns:
- the locale
 
 - 
setLocalepublic void setLocale(java.lang.String localeName) Set the locale used to format timestamps in log entries and in log file name suffix. Changing the locale is only supported as long as the AccessLogValve has not logged anything. Changing the locale later can lead to inconsistent formatting.- Parameters:
- localeName- The locale to use.
 
 - 
invokepublic void invoke(Request request, Response response) throws java.io.IOException, ServletException Log a message summarizing the specified request and response, according to the format specified by thepatternproperty.- Specified by:
- invokein interface- Valve
- Parameters:
- request- Request being processed
- response- Response being processed
- Throws:
- java.io.IOException- if an input/output error has occurred
- ServletException- if a servlet error has occurred
 
 - 
logpublic void log(Request request, Response response, long time) Description copied from interface:AccessLogAdd the request/response to the access log using the specified processing time.- Specified by:
- login interface- AccessLog
- Parameters:
- request- Request (associated with the response) to log
- response- Response (associated with the request) to log
- time- Time taken to process the request/response in nanoseconds (use 0 if not known); in Tomcat versions prior to 10, the time unit was milliseconds
 
 - 
logprotected abstract void log(java.io.CharArrayWriter message) Log the specified message.- Parameters:
- message- Message to be logged. This object will be recycled by the calling method.
 
 - 
findLocaleprotected static java.util.Locale findLocale(java.lang.String name, java.util.Locale fallback)Find a locale by name.- Parameters:
- name- The locale name
- fallback- Fallback locale if the name is not found
- Returns:
- the locale object
 
 - 
startInternalprotected void startInternal() throws LifecycleExceptionStart this component and implement the requirements ofLifecycleBase.startInternal().- Overrides:
- startInternalin class- ValveBase
- Throws:
- LifecycleException- if this component detects a fatal error that prevents this component from being used
 
 - 
stopInternalprotected void stopInternal() throws LifecycleExceptionStop this component and implement the requirements ofLifecycleBase.stopInternal().- Overrides:
- stopInternalin class- ValveBase
- Throws:
- LifecycleException- if this component detects a fatal error that prevents this component from being used
 
 - 
createLogElementsprotected AbstractAccessLogValve.AccessLogElement[] createLogElements() Parse pattern string and create the array of AccessLogElement.- Returns:
- the log elements array
 
 - 
createAccessLogElementprotected AbstractAccessLogValve.AccessLogElement createAccessLogElement(java.lang.String name, char pattern) Create an AccessLogElement implementation which needs an element name.- Parameters:
- name- Header name
- pattern- char in the log pattern
- Returns:
- the log element
 
 - 
createAccessLogElementprotected AbstractAccessLogValve.AccessLogElement createAccessLogElement(char pattern) Create an AccessLogElement implementation.- Parameters:
- pattern- char in the log pattern
- Returns:
- the log element
 
 - 
escapeAndAppendprotected static void escapeAndAppend(java.lang.String input, java.io.CharArrayWriter dest)
 
- 
 
-