Interface ServletConnection
public interface ServletConnection
Provides information about the connection made to the Servlet container. This interface is intended primarily for
 debugging purposes and as such provides the raw information as seen by the container. Unless explicitly stated
 otherwise in the Javadoc for a method, no adjustment is made for the presence of reverse proxies or similar
 configurations.
- Since:
- Servlet 6.0
- 
Method SummaryModifier and TypeMethodDescriptionObtain a unique (within the lifetime of the JVM) identifier string for the network connection to the JVM that is being used for theServletRequestfrom which thisServletConnectionwas obtained.Obtain the name of the protocol as presented to the server after the removal, if present, of any TLS or similar encryption.Obtain the connection identifier for the network connection to the server that is being used for theServletRequestfrom which thisServletConnectionwas obtained as defined by the protocol in use.booleanisSecure()Determine whether or not the incoming network connection to the server used encryption or not.
- 
Method Details- 
getConnectionIdString getConnectionId()Obtain a unique (within the lifetime of the JVM) identifier string for the network connection to the JVM that is being used for theServletRequestfrom which thisServletConnectionwas obtained.There is no defined format for this string. The format is implementation dependent. - Returns:
- A unique identifier for the network connection
 
- 
getProtocolString getProtocol()Obtain the name of the protocol as presented to the server after the removal, if present, of any TLS or similar encryption. This may not be the same as the protocol seen by the application. For example, a reverse proxy may present AJP whereas the application will see HTTP 1.1.If the protocol has an entry in the IANA registry for ALPN names then the identification sequence, in string form, must be returned. Registered identification sequences MUST only be used for the associated protocol. Return values for other protocols are implementation dependent. Unknown protocols should return the string "unknown". - Returns:
- The name of the protocol presented to the server after decryption of TLS, or similar encryption, if any.
 
- 
getProtocolConnectionIdString getProtocolConnectionId()Obtain the connection identifier for the network connection to the server that is being used for theServletRequestfrom which thisServletConnectionwas obtained as defined by the protocol in use. Note that some protocols do not define such an identifier.Examples of protocol provided connection identifiers include: - HTTP 1.x
- None, so the empty string should be returned
- HTTP 2
- None, so the empty string should be returned
- HTTP 3
- The QUIC connection ID
- AJP
- None, so the empty string should be returned
 - Returns:
- The connection identifier if one is defined, otherwise an empty string
 
- 
isSecureboolean isSecure()Determine whether or not the incoming network connection to the server used encryption or not. Note that where a reverse proxy is used, the application may have a different view as to whether encryption is being used due to the use of headers likeX-Forwarded-Proto.- Returns:
- trueif the incoming network connection used encryption, otherwise- false
 
 
-