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_config module.
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
 enableLookups for 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 millis
 %T - Time taken to process the request, in seconds
 %F - Time taken to commit the response, in millis
 %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:
%h %l %u %t "%r" %s %b
 %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}i for incoming headers
 %{xxx}o for outgoing response headers
 %{xxx}c for a specific cookie
 %{xxx}r xxx is an attribute in the ServletRequest
 %{xxx}s xxx is an attribute in the HttpSession
 %{xxx}t xxx is an enhanced SimpleDateFormat pattern
 (see Configuration Reference document for details on supported time patterns)
 
 Conditional logging is also supported. This can be done with the
 conditionUnless and conditionIf properties.
 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.
 The condition attribute is synonym for
 conditionUnless and 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.
| Modifier and Type | Class and Description | 
|---|---|
| protected static interface  | AbstractAccessLogValve.AccessLogElementAccessLogElement writes the partial message into the buffer. | 
| protected static class  | AbstractAccessLogValve.ByteSentElementwrite bytes sent, excluding HTTP headers - %b, %B | 
| protected static interface  | AbstractAccessLogValve.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 class  | AbstractAccessLogValve.ConnectionStatusElementWrite connection status when response is completed - %X | 
| protected static class  | AbstractAccessLogValve.CookieElementwrite a specific cookie - %{xxx}c | 
| protected class  | AbstractAccessLogValve.DateAndTimeElementwrite date and time, in configurable format (default CLF) - %t or %{format}t | 
| protected static class  | AbstractAccessLogValve.DateFormatCacheCache structure for formatted timestamps based on seconds. | 
| protected static class  | AbstractAccessLogValve.ElapsedTimeElementwrite time taken to process the request - %D, %T | 
| protected static class  | AbstractAccessLogValve.FirstByteTimeElementwrite time until first byte is written (commit time) in millis - %F | 
| protected static class  | AbstractAccessLogValve.HeaderElementwrite incoming headers - %{xxx}i | 
| protected class  | AbstractAccessLogValve.HostElementwrite remote host name - %h | 
| protected static class  | AbstractAccessLogValve.HttpStatusCodeElementwrite HTTP status code of the response - %s | 
| protected static class  | AbstractAccessLogValve.LocalAddrElementwrite local IP address - %A | 
| protected class  | AbstractAccessLogValve.LocalServerNameElementwrite local server name - %v | 
| protected static class  | AbstractAccessLogValve.LogicalUserNameElementwrite remote logical username from identd (always returns '-') - %l | 
| protected static class  | AbstractAccessLogValve.MethodElementwrite request method (GET, POST, etc.) - %m | 
| protected class  | AbstractAccessLogValve.PortElementwrite local or remote port for request connection - %p and %{xxx}p | 
| protected class  | AbstractAccessLogValve.ProtocolElementwrite request protocol - %H | 
| protected static class  | AbstractAccessLogValve.QueryElementwrite Query string (prepended with a '?' | 
| protected class  | AbstractAccessLogValve.RemoteAddrElementwrite remote IP address - %a | 
| protected static class  | AbstractAccessLogValve.RequestAttributeElementwrite an attribute in the ServletRequest - %{xxx}r | 
| protected static class  | AbstractAccessLogValve.RequestElementwrite first line of the request (method and request URI) - %r | 
| protected static class  | AbstractAccessLogValve.RequestURIElementwrite requested URL path - %U | 
| protected static class  | AbstractAccessLogValve.ResponseHeaderElementwrite a specific response header - %{xxx}o | 
| protected static class  | AbstractAccessLogValve.SessionAttributeElementwrite an attribute in the HttpSession - %{xxx}s | 
| protected static class  | AbstractAccessLogValve.SessionIdElementwrite user session ID - %S | 
| protected static class  | AbstractAccessLogValve.StringElementwrite any string | 
| protected static class  | AbstractAccessLogValve.ThreadNameElementwrite thread name - %I | 
| protected static class  | AbstractAccessLogValve.UserElementwrite remote user that was authenticated (if any), else '-' - %u | 
Lifecycle.SingleUse| Modifier and Type | Field and Description | 
|---|---|
| protected AbstractAccessLogValve.CachedElement[] | cachedElementsArray of elements where the value needs to be cached at the start of the
 request. | 
| protected String | conditionAre we doing conditional logging. default null. | 
| protected String | conditionIfAre we doing conditional logging. default null. | 
| protected boolean | enabledenabled this component | 
| protected Locale | localeLocale used to format timestamps in log entries and in
 log file name suffix. | 
| protected String | localeNameName 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 String | patternThe pattern used to format our access log lines. | 
| protected boolean | requestAttributesEnabledShould this valve use request attributes for IP address, hostname,
 protocol and port used for the request. | 
asyncSupported, container, containerLog, next, smmserverPROTOCOL_ATTRIBUTE, REMOTE_ADDR_ATTRIBUTE, REMOTE_HOST_ATTRIBUTE, SERVER_NAME_ATTRIBUTE, SERVER_PORT_ATTRIBUTEAFTER_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 and Description | 
|---|
| AbstractAccessLogValve() | 
| Modifier and Type | Method and Description | 
|---|---|
| protected AbstractAccessLogValve.AccessLogElement | createAccessLogElement(char pattern)Create an AccessLogElement implementation. | 
| protected AbstractAccessLogValve.AccessLogElement | createAccessLogElement(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 void | escapeAndAppend(String input,
               CharArrayWriter dest) | 
| protected static Locale | findLocale(String name,
          Locale fallback)Find a locale by name. | 
| String | getCondition()Return whether the attribute name to look for when
 performing conditional logging. | 
| String | getConditionIf()Return whether the attribute name to look for when
 performing conditional logging. | 
| String | getConditionUnless()Return whether the attribute name to look for when
 performing conditional logging. | 
| boolean | getEnabled() | 
| boolean | getIpv6Canonical() | 
| String | getLocale()Return the locale used to format timestamps in log entries and in
 log file name suffix. | 
| int | getMaxLogMessageBufferSize() | 
| String | getPattern() | 
| boolean | getRequestAttributesEnabled() | 
| void | invoke(Request request,
      Response response)Log a message summarizing the specified request and response, according
 to the format specified by the  patternproperty. | 
| protected abstract void | log(CharArrayWriter message)Log the specified message. | 
| void | log(Request request,
   Response response,
   long time)Add the request/response to the access log using the specified processing
 time. | 
| void | setCondition(String condition)Set the ServletRequest.attribute to look for to perform
 conditional logging. | 
| void | setConditionIf(String condition)Set the ServletRequest.attribute to look for to perform
 conditional logging. | 
| void | setConditionUnless(String condition)Set the ServletRequest.attribute to look for to perform
 conditional logging. | 
| void | setEnabled(boolean enabled) | 
| void | setIpv6Canonical(boolean ipv6Canonical) | 
| void | setLocale(String localeName)Set the locale used to format timestamps in log entries and in
 log file name suffix. | 
| void | setMaxLogMessageBufferSize(int maxLogMessageBufferSize) | 
| void | setPattern(String pattern)Set the format pattern, first translating any recognized alias. | 
| void | setRequestAttributesEnabled(boolean requestAttributesEnabled)Should this valve use request attributes for IP address, hostname,
 protocol and port used for the request? | 
| protected void | startInternal()Start this component and implement the requirements
 of  LifecycleBase.startInternal(). | 
| protected void | stopInternal()Stop this component and implement the requirements
 of  LifecycleBase.stopInternal(). | 
backgroundProcess, getContainer, getDomainInternal, getNext, getObjectNameKeyProperties, initInternal, isAsyncSupported, setAsyncSupported, setContainer, setNext, toStringdestroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregisteraddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stopprotected boolean enabled
protected String pattern
protected String condition
conditionUnless property.protected String conditionIf
conditionIf property.protected String localeName
protected Locale locale
protected AbstractAccessLogValve.AccessLogElement[] logElements
protected AbstractAccessLogValve.CachedElement[] cachedElements
protected boolean requestAttributesEnabled
false.setRequestAttributesEnabled(boolean)public int getMaxLogMessageBufferSize()
public void setMaxLogMessageBufferSize(int maxLogMessageBufferSize)
public boolean getIpv6Canonical()
public void setIpv6Canonical(boolean ipv6Canonical)
public void setRequestAttributesEnabled(boolean requestAttributesEnabled)
false.setRequestAttributesEnabled in interface AccessLogrequestAttributesEnabled - true causes the attributes
                                  to be used, false causes
                                  the original values to be used.public boolean getRequestAttributesEnabled()
getRequestAttributesEnabled in interface AccessLogtrue if the attributes will be logged, otherwise
         falseAccessLog.setRequestAttributesEnabled(boolean)public boolean getEnabled()
public void setEnabled(boolean enabled)
enabled - The enabled to set.public String getPattern()
public void setPattern(String pattern)
pattern - The new patternpublic String getCondition()
public void setCondition(String condition)
condition - Set to null to log everythingpublic String getConditionUnless()
public void setConditionUnless(String condition)
condition - Set to null to log everythingpublic String getConditionIf()
public void setConditionIf(String condition)
condition - Set to null to log everythingpublic String getLocale()
public void setLocale(String localeName)
localeName - The locale to use.public void invoke(Request request, Response response) throws IOException, ServletException
pattern property.invoke in interface Valverequest - Request being processedresponse - Response being processedIOException - if an input/output error has occurredServletException - if a servlet error has occurredpublic void log(Request request, Response response, long time)
AccessLogprotected abstract void log(CharArrayWriter message)
message - Message to be logged. This object will be recycled by
  the calling method.protected static Locale findLocale(String name, Locale fallback)
name - The locale namefallback - Fallback locale if the name is not foundprotected void startInternal()
                      throws LifecycleException
LifecycleBase.startInternal().startInternal in class ValveBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected void stopInternal()
                     throws LifecycleException
LifecycleBase.stopInternal().stopInternal in class ValveBaseLifecycleException - if this component detects a fatal error
  that prevents this component from being usedprotected AbstractAccessLogValve.AccessLogElement[] createLogElements()
protected AbstractAccessLogValve.AccessLogElement createAccessLogElement(String name, char pattern)
name - Header namepattern - char in the log patternprotected AbstractAccessLogValve.AccessLogElement createAccessLogElement(char pattern)
pattern - char in the log patternprotected static void escapeAndAppend(String input, CharArrayWriter dest)
Copyright © 2000-2021 Apache Software Foundation. All Rights Reserved.