Class RewriteValve
java.lang.Object
org.apache.catalina.util.LifecycleBase
org.apache.catalina.util.LifecycleMBeanBase
org.apache.catalina.valves.ValveBase
org.apache.catalina.valves.rewrite.RewriteValve
- All Implemented Interfaces:
MBeanRegistration
,Contained
,JmxEnabled
,Lifecycle
,Valve
Note: Extra caution should be used when adding a Rewrite Rule. When specifying a regex to match for in a Rewrite
Rule, certain regex could allow an attacker to DoS your server, as Java's regex parsing is vulnerable to
"catastrophic backtracking" (also known as "Regular expression Denial of Service", or ReDoS). There are some open
source tools to help detect vulnerable regex, though in general it is a hard problem. A good defence is to use a
regex debugger on your desired regex, and read more on the subject of catastrophic backtracking.
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.apache.catalina.Lifecycle
Lifecycle.SingleUse
-
Field Summary
Modifier and TypeFieldDescriptionprotected boolean
Will be set to true if the valve is associated with a context.protected boolean
enabled this componentprotected ThreadLocal<Boolean>
If rewriting occurs, the whole request will be processed again.protected Map<String,
RewriteMap> Maps to be used by the rules.Maps configuration.protected String
Relative path to the configuration file.protected RewriteRule[]
The rewrite rules that the valve will use.Fields inherited from class org.apache.catalina.valves.ValveBase
asyncSupported, container, containerLog, next, sm
Fields inherited from class org.apache.catalina.util.LifecycleMBeanBase
mserver
Fields inherited from interface org.apache.catalina.Lifecycle
AFTER_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 Summary
-
Method Summary
Modifier and TypeMethodDescriptionboolean
protected void
Sub-classes implement this method to perform any instance initialisation required.void
Perform request processing as required by this Valve.protected void
parse
(BufferedReader reader) static Object
This factory method will parse a line formed like:protected static void
parseCondFlag
(String line, RewriteCond condition, String flag) Parser for RewriteCond flags.protected static void
parseRuleFlag
(String line, RewriteRule rule, String flag) Parser for RewriteRule flags.void
setConfiguration
(String configuration) void
setEnabled
(boolean enabled) protected void
Start this component and implement the requirements ofLifecycleBase.startInternal()
.protected void
Stop this component and implement the requirements ofLifecycleBase.stopInternal()
.Methods inherited from class org.apache.catalina.valves.ValveBase
backgroundProcess, getContainer, getDomainInternal, getNext, getObjectNameKeyProperties, isAsyncSupported, setAsyncSupported, setContainer, setNext, toString
Methods inherited from class org.apache.catalina.util.LifecycleMBeanBase
destroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister, unregister
Methods inherited from class org.apache.catalina.util.LifecycleBase
addLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stop
-
Field Details
-
rules
The rewrite rules that the valve will use. -
invoked
If rewriting occurs, the whole request will be processed again. -
resourcePath
Relative path to the configuration file. Note: If the valve's container is a context, this will be relative to /WEB-INF/. -
context
protected boolean contextWill be set to true if the valve is associated with a context. -
enabled
protected boolean enabledenabled this component -
maps
Maps to be used by the rules. -
mapsConfiguration
Maps configuration.
-
-
Constructor Details
-
RewriteValve
public RewriteValve()
-
-
Method Details
-
getEnabled
public boolean getEnabled() -
setEnabled
public void setEnabled(boolean enabled) -
initInternal
Description copied from class:LifecycleBase
Sub-classes implement this method to perform any instance initialisation required.- Overrides:
initInternal
in classValveBase
- Throws:
LifecycleException
- If the initialisation fails
-
startInternal
Description copied from class:ValveBase
Start this component and implement the requirements ofLifecycleBase.startInternal()
.- Overrides:
startInternal
in classValveBase
- Throws:
LifecycleException
- if this component detects a fatal error that prevents this component from being used
-
setConfiguration
- Throws:
Exception
-
getConfiguration
-
parse
- Throws:
LifecycleException
-
stopInternal
Description copied from class:ValveBase
Stop this component and implement the requirements ofLifecycleBase.stopInternal()
.- Overrides:
stopInternal
in classValveBase
- Throws:
LifecycleException
- if this component detects a fatal error that prevents this component from being used
-
invoke
Description copied from interface:Valve
Perform request processing as required by this Valve.
An individual Valve MAY perform the following actions, in the specified order:
- Examine and/or modify the properties of the specified Request and Response.
- Examine the properties of the specified Request, completely generate the corresponding Response, and return control to the caller.
- Examine the properties of the specified Request and Response, wrap either or both of these objects to supplement their functionality, and pass them on.
- If the corresponding Response was not generated (and control was not returned, call the next Valve in the
pipeline (if there is one) by executing
getNext().invoke()
. - Examine, but not modify, the properties of the resulting Response (which was created by a subsequently invoked Valve or Container).
A Valve MUST NOT do any of the following things:
- Change request properties that have already been used to direct the flow of processing control for this request (for instance, trying to change the virtual host to which a Request should be sent from a pipeline attached to a Host or Context in the standard implementation).
- Create a completed Response AND pass this Request and Response on to the next Valve in the pipeline.
- Consume bytes from the input stream associated with the Request, unless it is completely generating the response, or wrapping the request before passing it on.
- Modify the HTTP headers included with the Response after the
getNext().invoke()
method has returned. - Perform any actions on the output stream associated with the specified Response after the
getNext().invoke()
method has returned.
- Parameters:
request
- The servlet request to be processedresponse
- The servlet response to be created- Throws:
IOException
- if an input/output error occurs, or is thrown by a subsequently invoked Valve, Filter, or ServletServletException
- if a servlet error occurs, or is thrown by a subsequently invoked Valve, Filter, or Servlet
-
parse
This factory method will parse a line formed like:Example:
RewriteCond %{REMOTE_HOST} ^host1.* [OR]
- Parameters:
line
- A line from the rewrite configuration- Returns:
- The condition, rule or map resulting from parsing the line
-
parseCondFlag
Parser for RewriteCond flags.- Parameters:
line
- The configuration line being parsedcondition
- The current conditionflag
- The flag
-
parseRuleFlag
Parser for RewriteRule flags.- Parameters:
line
- The configuration line being parsedrule
- The current ruleflag
- The flag
-