Package de.aristaflow.adept2.util.net
Class HttpTools
- java.lang.Object
-
- de.aristaflow.adept2.util.net.HttpTools
-
public class HttpTools extends Object
Tool methods for simplifying life with HTTP.
-
-
Field Summary
Fields Modifier and Type Field Description static String
HEADER_FORWARDED
The header name for forward information for HTTP requests through a proxy.static String
HEADER_X_FORWARDED_HOST
The header name for the forward host for HTTP requests through a proxy.static String
HEADER_X_FORWARDED_PORT
The header name for the forward port for HTTP requests through a proxy.static String
HEADER_X_FORWARDED_PROTO
The header name for the forward protocol for HTTP requests through a proxy.protected static Pattern
hostPattern
The pattern determining the host and port from the Forwarded header.protected static Pattern
protoPattern
The pattern determining the protocol from the Forwarded header.
-
Constructor Summary
Constructors Constructor Description HttpTools()
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static String
adaptUrl(String url, Function<String,String> headers, Logger logger)
Adapts the designated URL by transforming the string to a URL, applyingadaptUrl(URL, Function, Logger)
and converting the URL back to String again.static URL
adaptUrl(URL url, Function<String,String> headers, Logger logger)
Adapts the designated URL by setting protocol, host and port from the headers provided by the designated function.
-
-
-
Field Detail
-
HEADER_FORWARDED
public static final String HEADER_FORWARDED
The header name for forward information for HTTP requests through a proxy.- See Also:
- Forwarded, Constant Field Values
-
HEADER_X_FORWARDED_HOST
public static final String HEADER_X_FORWARDED_HOST
The header name for the forward host for HTTP requests through a proxy.- See Also:
- X-Forwarded-Host, Constant Field Values
-
HEADER_X_FORWARDED_PORT
public static final String HEADER_X_FORWARDED_PORT
The header name for the forward port for HTTP requests through a proxy.- See Also:
- Constant Field Values
-
HEADER_X_FORWARDED_PROTO
public static final String HEADER_X_FORWARDED_PROTO
The header name for the forward protocol for HTTP requests through a proxy.- See Also:
- X-Forwarded-Proto, Constant Field Values
-
hostPattern
protected static final Pattern hostPattern
The pattern determining the host and port from the Forwarded header.
-
protoPattern
protected static final Pattern protoPattern
The pattern determining the protocol from the Forwarded header.
-
-
Method Detail
-
adaptUrl
public static String adaptUrl(String url, Function<String,String> headers, Logger logger)
Adapts the designated URL by transforming the string to a URL, applyingadaptUrl(URL, Function, Logger)
and converting the URL back to String again.- Parameters:
url
- The URL which may need to be adapted to a different protocol, host and/or port. This must not benull
.headers
- The function providing HTTP request headers. This must not benull
but it may returnnull
.logger
- The logger for logging problems, e. g. the port cannot be converted toint
. This must not benull
.- Returns:
- The URL with protocol, host and/or port changed to the values provided by the
designated
headers
function for the corresponding HTTP headers. - See Also:
adaptUrl(URL, Function, Logger)
-
adaptUrl
public static URL adaptUrl(URL url, Function<String,String> headers, Logger logger)
Adapts the designated URL by setting protocol, host and port from the headers provided by the designated function. This allows to change the known values to the ones provided by the HTTP request which may be routed through a proxy. That is, the URL working for the requestor may need to be different from the URL known by our service.This supports (in this order, i. e. if a value is provided, the corresponding alternative header will be ignored):
- Forwarded
- X-Forwarded-Host
- X-Forwarded-Port
- X-Forwarded-Proto
- Parameters:
url
- The URL which may need to be adapted to a different protocol, host and/or port. This must not benull
.headers
- The function providing HTTP request headers. This must not benull
but it may returnnull
.logger
- The logger for logging problems, e. g. the port cannot be converted toint
. This must not benull
.- Returns:
- The URL with protocol, host and/or port changed to the values provided by the
designated
headers
function for the corresponding HTTP headers.
-
-