public class SSLValve extends ValveBase
Note: Ensure that the headers are always set by httpd for all requests to prevent a client spoofing SSL information by sending fake headers.
In httpd.conf add the following:
<IfModule ssl_module> RequestHeader set SSL_CLIENT_CERT "%{SSL_CLIENT_CERT}s" RequestHeader set SSL_CIPHER "%{SSL_CIPHER}s" RequestHeader set SSL_SESSION_ID "%{SSL_SESSION_ID}s" RequestHeader set SSL_CIPHER_USEKEYSIZE "%{SSL_CIPHER_USEKEYSIZE}s" </IfModule>In server.xml, configure this valve under the Engine element in server.xml:
<Engine ...> <Valve className="org.apache.catalina.valves.SSLValve" /> <Host ... /> </Engine>
Lifecycle.SingleUse
asyncSupported, container, containerLog, next, sm
mserver
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 and Description |
---|
SSLValve() |
Modifier and Type | Method and Description |
---|---|
String |
getSslCipherHeader() |
String |
getSslCipherUserKeySizeHeader() |
String |
getSslClientCertHeader() |
String |
getSslSessionIdHeader() |
void |
invoke(Request request,
Response response)
Perform request processing as required by this Valve.
|
String |
mygetHeader(Request request,
String header) |
void |
setSslCipherHeader(String sslCipherHeader) |
void |
setSslCipherUserKeySizeHeader(String sslCipherUserKeySizeHeader) |
void |
setSslClientCertHeader(String sslClientCertHeader) |
void |
setSslSessionIdHeader(String sslSessionIdHeader) |
backgroundProcess, getContainer, getDomainInternal, getNext, getObjectNameKeyProperties, initInternal, isAsyncSupported, setAsyncSupported, setContainer, setNext, startInternal, stopInternal, toString
destroyInternal, getDomain, getObjectName, postDeregister, postRegister, preDeregister, preRegister, register, setDomain, unregister
addLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, init, removeLifecycleListener, setState, setState, start, stop
public String getSslClientCertHeader()
public void setSslClientCertHeader(String sslClientCertHeader)
public String getSslCipherHeader()
public void setSslCipherHeader(String sslCipherHeader)
public String getSslSessionIdHeader()
public void setSslSessionIdHeader(String sslSessionIdHeader)
public String getSslCipherUserKeySizeHeader()
public void setSslCipherUserKeySizeHeader(String sslCipherUserKeySizeHeader)
public void invoke(Request request, Response response) throws IOException, ServletException
Valve
Perform request processing as required by this Valve.
An individual Valve MAY perform the following actions, in the specified order:
getNext().invoke()
.
A Valve MUST NOT do any of the following things:
getNext().invoke()
method has returned.
getNext().invoke()
method has
returned.
request
- The servlet request to be processedresponse
- The servlet response to be createdIOException
- 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 ServletCopyright © 2000-2016 Apache Software Foundation. All Rights Reserved.