|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.catalina.valves.ValveBase org.apache.catalina.valves.AccessLogValve
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 mod_log_config
module. As an additional feature,
automatic rollover of log files when the date changes is also supported.
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:
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 syntax:
%{xxx}i
for incoming 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
Conditional logging is also supported. This can be done with the
condition
property.
If the value returned from ServletRequest.getAttribute(condition)
yields a non-null value. The logging will be skipped.
Field Summary | |
protected static java.lang.String |
info
The descriptive information about this implementation. |
protected LifecycleSupport |
lifecycle
The lifecycle event support for this component. |
protected static java.lang.String[] |
months
The set of month abbreviations for log messages. |
Fields inherited from class org.apache.catalina.valves.ValveBase |
container, controller, debug, domain, mserver, oname |
Fields inherited from interface org.apache.catalina.Lifecycle |
AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, START_EVENT, STOP_EVENT |
Constructor Summary | |
AccessLogValve()
Construct a new instance of this class with default property values. |
Method Summary | |
void |
addLifecycleListener(LifecycleListener listener)
Add a lifecycle event listener to this component. |
LifecycleListener[] |
findLifecycleListeners()
Get the lifecycle listeners associated with this lifecycle. |
java.lang.String |
getCondition()
Return whether the attribute name to look for when performing conditional loggging. |
java.lang.String |
getDirectory()
Return the directory in which we create log files. |
java.lang.String |
getFileDateFormat()
Return the date format date based log rotation. |
java.lang.String |
getInfo()
Return descriptive information about this implementation. |
java.lang.String |
getPattern()
Return the format pattern. |
java.lang.String |
getPrefix()
Return the log file prefix. |
java.lang.String |
getSuffix()
Return the log file suffix. |
void |
invoke(Request request,
Response response,
ValveContext context)
Log a message summarizing the specified request and response, according to the format specified by the pattern property. |
boolean |
isResolveHosts()
Get the value of the resolve hosts flag. |
boolean |
isRotatable()
Should we rotate the logs |
void |
log(java.lang.String message,
java.util.Date date)
Log the specified message to the log file, switching files if the date has changed since the previous log call. |
void |
removeLifecycleListener(LifecycleListener listener)
Remove a lifecycle event listener from this component. |
void |
setCondition(java.lang.String condition)
Set the ServletRequest.attribute to look for to perform conditional logging. |
void |
setDirectory(java.lang.String directory)
Set the directory in which we create log files. |
void |
setFileDateFormat(java.lang.String fileDateFormat)
Set the date format date based log rotation. |
void |
setPattern(java.lang.String pattern)
Set the format pattern, first translating any recognized alias. |
void |
setPrefix(java.lang.String prefix)
Set the log file prefix. |
void |
setResolveHosts(boolean resolveHosts)
Set the resolve hosts flag. |
void |
setRotatable(boolean rotatable)
Set the value is we should we rotate the logs |
void |
setSuffix(java.lang.String suffix)
Set the log file suffix. |
void |
start()
Prepare for the beginning of active use of the public methods of this component. |
void |
stop()
Gracefully terminate the active use of the public methods of this component. |
Methods inherited from class org.apache.catalina.valves.ValveBase |
createObjectName, getContainer, getContainerName, getController, getDebug, getDomain, getObjectName, getParentName, postDeregister, postRegister, preDeregister, preRegister, setContainer, setController, setDebug, setObjectName |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
protected static final java.lang.String info
protected LifecycleSupport lifecycle
protected static final java.lang.String[] months
Constructor Detail |
public AccessLogValve()
Method Detail |
public java.lang.String getDirectory()
public void setDirectory(java.lang.String directory)
directory
- The new log file directorypublic java.lang.String getInfo()
getInfo
in interface Valve
getInfo
in class ValveBase
public java.lang.String getPattern()
public void setPattern(java.lang.String pattern)
pattern
- The new patternpublic java.lang.String getPrefix()
public void setPrefix(java.lang.String prefix)
prefix
- The new log file prefixpublic boolean isRotatable()
public void setRotatable(boolean rotatable)
rotatable
- true is we should rotate.public java.lang.String getSuffix()
public void setSuffix(java.lang.String suffix)
suffix
- The new log file suffixpublic void setResolveHosts(boolean resolveHosts)
resolveHosts
- The new resolve hosts valuepublic boolean isResolveHosts()
public java.lang.String getCondition()
public void setCondition(java.lang.String condition)
condition
- Set to null to log everythingpublic java.lang.String getFileDateFormat()
public void setFileDateFormat(java.lang.String fileDateFormat)
public void invoke(Request request, Response response, ValveContext context) throws java.io.IOException, javax.servlet.ServletException
pattern
property.
invoke
in interface Valve
invoke
in class ValveBase
request
- Request being processedresponse
- Response being processedcontext
- The valve context used to invoke the next valve
in the current processing pipeline
java.io.IOException
- if an input/output error has occurred
javax.servlet.ServletException
- if a servlet error has occurredpublic void log(java.lang.String message, java.util.Date date)
message
- Message to be loggeddate
- the current Date object (so this method doesn't need to
create a new one)public void addLifecycleListener(LifecycleListener listener)
addLifecycleListener
in interface Lifecycle
listener
- The listener to addpublic LifecycleListener[] findLifecycleListeners()
findLifecycleListeners
in interface Lifecycle
public void removeLifecycleListener(LifecycleListener listener)
removeLifecycleListener
in interface Lifecycle
listener
- The listener to addpublic void start() throws LifecycleException
configure()
,
and before any of the public methods of the component are utilized.
start
in interface Lifecycle
LifecycleException
- if this component detects a fatal error
that prevents this component from being usedpublic void stop() throws LifecycleException
stop
in interface Lifecycle
LifecycleException
- if this component detects a fatal error
that needs to be reported
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |