public class HttpHeaders extends java.lang.Object implements MultiValueMap<java.lang.String,java.lang.String>, java.io.Serializable
In addition to the regular methods defined by Map, this class offers many common
 convenience methods, for example:
 
getFirst(String) returns the first value associated with a given header nameadd(String, String) adds a header value to the list of values for a header nameset(String, String) sets the header value to a single string valueNote that HttpHeaders generally treats header names in a case-insensitive manner.
| Modifier and Type | Field and Description | 
|---|---|
| static java.lang.String | ACCEPTThe HTTP  Acceptheader field name. | 
| static java.lang.String | ACCEPT_CHARSETThe HTTP  Accept-Charsetheader field name. | 
| static java.lang.String | ACCEPT_ENCODINGThe HTTP  Accept-Encodingheader field name. | 
| static java.lang.String | ACCEPT_LANGUAGEThe HTTP  Accept-Languageheader field name. | 
| static java.lang.String | ACCEPT_RANGESThe HTTP  Accept-Rangesheader field name. | 
| static java.lang.String | ACCESS_CONTROL_ALLOW_CREDENTIALSThe CORS  Access-Control-Allow-Credentialsresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_ALLOW_HEADERSThe CORS  Access-Control-Allow-Headersresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_ALLOW_METHODSThe CORS  Access-Control-Allow-Methodsresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_ALLOW_ORIGINThe CORS  Access-Control-Allow-Originresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_EXPOSE_HEADERSThe CORS  Access-Control-Expose-Headersresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_MAX_AGEThe CORS  Access-Control-Max-Ageresponse header field name. | 
| static java.lang.String | ACCESS_CONTROL_REQUEST_HEADERSThe CORS  Access-Control-Request-Headersrequest header field name. | 
| static java.lang.String | ACCESS_CONTROL_REQUEST_METHODThe CORS  Access-Control-Request-Methodrequest header field name. | 
| static java.lang.String | AGEThe HTTP  Ageheader field name. | 
| static java.lang.String | ALLOWThe HTTP  Allowheader field name. | 
| static java.lang.String | AUTHORIZATIONThe HTTP  Authorizationheader field name. | 
| static java.lang.String | CACHE_CONTROLThe HTTP  Cache-Controlheader field name. | 
| static java.lang.String | CONNECTIONThe HTTP  Connectionheader field name. | 
| static java.lang.String | CONTENT_DISPOSITIONThe HTTP  Content-Dispositionheader field name. | 
| static java.lang.String | CONTENT_ENCODINGThe HTTP  Content-Encodingheader field name. | 
| static java.lang.String | CONTENT_LANGUAGEThe HTTP  Content-Languageheader field name. | 
| static java.lang.String | CONTENT_LENGTHThe HTTP  Content-Lengthheader field name. | 
| static java.lang.String | CONTENT_LOCATIONThe HTTP  Content-Locationheader field name. | 
| static java.lang.String | CONTENT_RANGEThe HTTP  Content-Rangeheader field name. | 
| static java.lang.String | CONTENT_TYPEThe HTTP  Content-Typeheader field name. | 
| static java.lang.String | COOKIEThe HTTP  Cookieheader field name. | 
| static java.lang.String | DATEThe HTTP  Dateheader field name. | 
| private static java.time.format.DateTimeFormatter | DATE_FORMATTERDate formats with time zone as specified in the HTTP RFC to use for formatting. | 
| private static java.time.format.DateTimeFormatter[] | DATE_PARSERSDate formats with time zone as specified in the HTTP RFC to use for parsing. | 
| private static java.text.DecimalFormatSymbols | DECIMAL_FORMAT_SYMBOLS | 
| static HttpHeaders | EMPTYAn empty  HttpHeadersinstance (immutable). | 
| static java.lang.String | ETAGThe HTTP  ETagheader field name. | 
| private static java.util.regex.Pattern | ETAG_HEADER_VALUE_PATTERNPattern matching ETag multiple field values in headers such as "If-Match", "If-None-Match". | 
| static java.lang.String | EXPECTThe HTTP  Expectheader field name. | 
| static java.lang.String | EXPIRESThe HTTP  Expiresheader field name. | 
| static java.lang.String | FROMThe HTTP  Fromheader field name. | 
| private static java.time.ZoneId | GMT | 
| (package private) MultiValueMap<java.lang.String,java.lang.String> | headers | 
| static java.lang.String | HOSTThe HTTP  Hostheader field name. | 
| static java.lang.String | IF_MATCHThe HTTP  If-Matchheader field name. | 
| static java.lang.String | IF_MODIFIED_SINCEThe HTTP  If-Modified-Sinceheader field name. | 
| static java.lang.String | IF_NONE_MATCHThe HTTP  If-None-Matchheader field name. | 
| static java.lang.String | IF_RANGEThe HTTP  If-Rangeheader field name. | 
| static java.lang.String | IF_UNMODIFIED_SINCEThe HTTP  If-Unmodified-Sinceheader field name. | 
| static java.lang.String | LAST_MODIFIEDThe HTTP  Last-Modifiedheader field name. | 
| static java.lang.String | LINKThe HTTP  Linkheader field name. | 
| static java.lang.String | LOCATIONThe HTTP  Locationheader field name. | 
| static java.lang.String | MAX_FORWARDSThe HTTP  Max-Forwardsheader field name. | 
| static java.lang.String | ORIGINThe HTTP  Originheader field name. | 
| static java.lang.String | PRAGMAThe HTTP  Pragmaheader field name. | 
| static java.lang.String | PROXY_AUTHENTICATEThe HTTP  Proxy-Authenticateheader field name. | 
| static java.lang.String | PROXY_AUTHORIZATIONThe HTTP  Proxy-Authorizationheader field name. | 
| static java.lang.String | RANGEThe HTTP  Rangeheader field name. | 
| static java.lang.String | REFERERThe HTTP  Refererheader field name. | 
| static java.lang.String | RETRY_AFTERThe HTTP  Retry-Afterheader field name. | 
| private static long | serialVersionUID | 
| static java.lang.String | SERVERThe HTTP  Serverheader field name. | 
| static java.lang.String | SET_COOKIEThe HTTP  Set-Cookieheader field name. | 
| static java.lang.String | SET_COOKIE2The HTTP  Set-Cookie2header field name. | 
| static java.lang.String | TEThe HTTP  TEheader field name. | 
| static java.lang.String | TRAILERThe HTTP  Trailerheader field name. | 
| static java.lang.String | TRANSFER_ENCODINGThe HTTP  Transfer-Encodingheader field name. | 
| static java.lang.String | UPGRADEThe HTTP  Upgradeheader field name. | 
| static java.lang.String | USER_AGENTThe HTTP  User-Agentheader field name. | 
| static java.lang.String | VARYThe HTTP  Varyheader field name. | 
| static java.lang.String | VIAThe HTTP  Viaheader field name. | 
| static java.lang.String | WARNINGThe HTTP  Warningheader field name. | 
| static java.lang.String | WWW_AUTHENTICATEThe HTTP  WWW-Authenticateheader field name. | 
| Constructor and Description | 
|---|
| HttpHeaders()Construct a new, empty instance of the  HttpHeadersobject. | 
| HttpHeaders(MultiValueMap<java.lang.String,java.lang.String> headers)Construct a new  HttpHeadersinstance backed by an existing map. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | add(java.lang.String headerName,
   java.lang.String headerValue)Add the given, single header value under the given name. | 
| void | addAll(MultiValueMap<java.lang.String,java.lang.String> values)Add all the values of the given  MultiValueMapto the current values. | 
| void | addAll(java.lang.String key,
      java.util.List<? extends java.lang.String> values)Add all the values of the given list to the current list of values for the given key. | 
| void | clear() | 
| boolean | containsKey(java.lang.Object key) | 
| boolean | containsValue(java.lang.Object value) | 
| java.util.Set<java.util.Map.Entry<java.lang.String,java.util.List<java.lang.String>>> | entrySet() | 
| boolean | equals(java.lang.Object other) | 
| (package private) static java.lang.String | formatDate(long date) | 
| static java.lang.String | formatHeaders(MultiValueMap<java.lang.String,java.lang.String> headers)Helps to format HTTP header values, as HTTP header values themselves can
 contain comma-separated values, can become confusing with regular
  Mapformatting that also uses commas between entries. | 
| java.util.List<java.lang.String> | get(java.lang.Object key) | 
| java.util.List<MediaType> | getAccept()Return the list of acceptable media types,
 as specified by the  Acceptheader. | 
| java.util.List<java.nio.charset.Charset> | getAcceptCharset()Return the list of acceptable charsets,
 as specified by the  Accept-Charsetheader. | 
| java.util.List<java.util.Locale.LanguageRange> | getAcceptLanguage()Return the language ranges from the "Accept-Language" header. | 
| java.util.List<java.util.Locale> | getAcceptLanguageAsLocales() | 
| boolean | getAccessControlAllowCredentials()Return the value of the  Access-Control-Allow-Credentialsresponse header. | 
| java.util.List<java.lang.String> | getAccessControlAllowHeaders()Return the value of the  Access-Control-Allow-Headersresponse header. | 
| java.util.List<HttpMethod> | getAccessControlAllowMethods()Return the value of the  Access-Control-Allow-Methodsresponse header. | 
| java.lang.String | getAccessControlAllowOrigin()Return the value of the  Access-Control-Allow-Originresponse header. | 
| java.util.List<java.lang.String> | getAccessControlExposeHeaders()Return the value of the  Access-Control-Expose-Headersresponse header. | 
| long | getAccessControlMaxAge()Return the value of the  Access-Control-Max-Ageresponse header. | 
| java.util.List<java.lang.String> | getAccessControlRequestHeaders()Return the value of the  Access-Control-Request-Headersrequest header. | 
| HttpMethod | getAccessControlRequestMethod()Return the value of the  Access-Control-Request-Methodrequest header. | 
| java.util.Set<HttpMethod> | getAllow()Return the set of allowed  HTTP methods,
 as specified by theAllowheader. | 
| java.lang.String | getCacheControl()Return the value of the  Cache-Controlheader. | 
| java.util.List<java.lang.String> | getConnection()Return the value of the  Connectionheader. | 
| ContentDisposition | getContentDisposition()Return a parsed representation of the Content-Disposition header. | 
| java.util.Locale | getContentLanguage()Return the first  Localeof the content languages,
 as specified by the Content-Language header. | 
| long | getContentLength()Return the length of the body in bytes, as specified by the
  Content-Lengthheader. | 
| MediaType | getContentType()Return the media type of the body, as specified
 by the  Content-Typeheader. | 
| long | getDate()Return the date and time at which the message was created, as specified
 by the  Dateheader. | 
| java.lang.String | getETag()Return the entity tag of the body, as specified by the  ETagheader. | 
| protected java.util.List<java.lang.String> | getETagValuesAsList(java.lang.String headerName)Retrieve a combined result from the field values of the ETag header. | 
| long | getExpires()Return the date and time at which the message is no longer valid,
 as specified by the  Expiresheader. | 
| protected java.lang.String | getFieldValues(java.lang.String headerName)Retrieve a combined result from the field values of multi-valued headers. | 
| java.lang.String | getFirst(java.lang.String headerName)Return the first header value for the given header name, if any. | 
| long | getFirstDate(java.lang.String headerName)Parse the first header value for the given header name as a date,
 return -1 if there is no value, or raise  IllegalArgumentExceptionif the value cannot be parsed as a date. | 
| private long | getFirstDate(java.lang.String headerName,
            boolean rejectInvalid)Parse the first header value for the given header name as a date,
 return -1 if there is no value or also in case of an invalid value
 (if  rejectInvalid=false), or raiseIllegalArgumentExceptionif the value cannot be parsed as a date. | 
| java.time.ZonedDateTime | getFirstZonedDateTime(java.lang.String headerName)Parse the first header value for the given header name as a date,
 return  nullif there is no value, or raiseIllegalArgumentExceptionif the value cannot be parsed as a date. | 
| private java.time.ZonedDateTime | getFirstZonedDateTime(java.lang.String headerName,
                     boolean rejectInvalid)Parse the first header value for the given header name as a date,
 return  nullif there is no value or also in case of an invalid value
 (ifrejectInvalid=false), or raiseIllegalArgumentExceptionif the value cannot be parsed as a date. | 
| java.net.InetSocketAddress | getHost()Return the value of the  Hostheader, if available. | 
| java.util.List<java.lang.String> | getIfMatch()Return the value of the  If-Matchheader. | 
| long | getIfModifiedSince()Return the value of the  If-Modified-Sinceheader. | 
| java.util.List<java.lang.String> | getIfNoneMatch()Return the value of the  If-None-Matchheader. | 
| long | getIfUnmodifiedSince()Return the value of the  If-Unmodified-Sinceheader. | 
| long | getLastModified()Return the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| java.net.URI | getLocation()Return the (new) location of a resource
 as specified by the  Locationheader. | 
| java.lang.String | getOrigin()Return the value of the  Originheader. | 
| java.lang.String | getPragma()Return the value of the  Pragmaheader. | 
| java.util.List<HttpRange> | getRange()Return the value of the  Rangeheader. | 
| java.lang.String | getUpgrade()Return the value of the  Upgradeheader. | 
| java.util.List<java.lang.String> | getValuesAsList(java.lang.String headerName)Return all values of a given header name,
 even if this header is set multiple times. | 
| java.util.List<java.lang.String> | getVary()Return the request header names subject to content negotiation. | 
| int | hashCode() | 
| boolean | isEmpty() | 
| java.util.Set<java.lang.String> | keySet() | 
| java.util.List<java.lang.String> | put(java.lang.String key,
   java.util.List<java.lang.String> value) | 
| void | putAll(java.util.Map<? extends java.lang.String,? extends java.util.List<java.lang.String>> map) | 
| static HttpHeaders | readOnlyHttpHeaders(HttpHeaders headers)Return an  HttpHeadersobject that can only be read, not written to. | 
| java.util.List<java.lang.String> | remove(java.lang.Object key) | 
| void | set(java.lang.String headerName,
   java.lang.String headerValue)Set the given, single header value under the given name. | 
| void | setAccept(java.util.List<MediaType> acceptableMediaTypes)Set the list of acceptable media types,
 as specified by the  Acceptheader. | 
| void | setAcceptCharset(java.util.List<java.nio.charset.Charset> acceptableCharsets)Set the list of acceptable charsets,
 as specified by the  Accept-Charsetheader. | 
| void | setAcceptLanguage(java.util.List<java.util.Locale.LanguageRange> languages)Set the acceptable language ranges, as specified by the
 Accept-Language header. | 
| void | setAcceptLanguageAsLocales(java.util.List<java.util.Locale> locales)Variant of  setAcceptLanguage(List)usingLocale's. | 
| void | setAccessControlAllowCredentials(boolean allowCredentials)Set the (new) value of the  Access-Control-Allow-Credentialsresponse header. | 
| void | setAccessControlAllowHeaders(java.util.List<java.lang.String> allowedHeaders)Set the (new) value of the  Access-Control-Allow-Headersresponse header. | 
| void | setAccessControlAllowMethods(java.util.List<HttpMethod> allowedMethods)Set the (new) value of the  Access-Control-Allow-Methodsresponse header. | 
| void | setAccessControlAllowOrigin(java.lang.String allowedOrigin)Set the (new) value of the  Access-Control-Allow-Originresponse header. | 
| void | setAccessControlExposeHeaders(java.util.List<java.lang.String> exposedHeaders)Set the (new) value of the  Access-Control-Expose-Headersresponse header. | 
| void | setAccessControlMaxAge(java.time.Duration maxAge)Set the (new) value of the  Access-Control-Max-Ageresponse header. | 
| void | setAccessControlMaxAge(long maxAge)Set the (new) value of the  Access-Control-Max-Ageresponse header. | 
| void | setAccessControlRequestHeaders(java.util.List<java.lang.String> requestHeaders)Set the (new) value of the  Access-Control-Request-Headersrequest header. | 
| void | setAccessControlRequestMethod(HttpMethod requestMethod)Set the (new) value of the  Access-Control-Request-Methodrequest header. | 
| void | setAll(java.util.Map<java.lang.String,java.lang.String> values)Set the given values under. | 
| void | setAllow(java.util.Set<HttpMethod> allowedMethods)Set the set of allowed  HTTP methods,
 as specified by theAllowheader. | 
| void | setBasicAuth(java.lang.String username,
            java.lang.String password)Set the value of the Authorization header to
 Basic Authentication based on the given username and password. | 
| void | setBasicAuth(java.lang.String username,
            java.lang.String password,
            java.nio.charset.Charset charset)Set the value of the Authorization header to
 Basic Authentication based on the given username and password. | 
| void | setBearerAuth(java.lang.String token)Set the value of the Authorization header to
 the given Bearer token. | 
| void | setCacheControl(CacheControl cacheControl)Set a configured  CacheControlinstance as the
 new value of theCache-Controlheader. | 
| void | setCacheControl(java.lang.String cacheControl)Set the (new) value of the  Cache-Controlheader. | 
| void | setConnection(java.util.List<java.lang.String> connection)Set the (new) value of the  Connectionheader. | 
| void | setConnection(java.lang.String connection)Set the (new) value of the  Connectionheader. | 
| void | setContentDisposition(ContentDisposition contentDisposition)Set the Content-Disposition header. | 
| void | setContentDispositionFormData(java.lang.String name,
                             java.lang.String filename)Set the  Content-Dispositionheader when creating a"multipart/form-data"request. | 
| void | setContentLanguage(java.util.Locale locale)Set the  Localeof the content language,
 as specified by the Content-Language header. | 
| void | setContentLength(long contentLength)Set the length of the body in bytes, as specified by the
  Content-Lengthheader. | 
| void | setContentType(MediaType mediaType)Set the media type of the body,
 as specified by the  Content-Typeheader. | 
| void | setDate(java.time.Instant date)Set the date and time at which the message was created, as specified
 by the  Dateheader. | 
| void | setDate(long date)Set the date and time at which the message was created, as specified
 by the  Dateheader. | 
| void | setDate(java.lang.String headerName,
       long date)Set the given date under the given header name after formatting it as a string
 using the RFC-1123 date-time formatter. | 
| void | setDate(java.time.ZonedDateTime date)Set the date and time at which the message was created, as specified
 by the  Dateheader. | 
| void | setETag(java.lang.String etag)Set the (new) entity tag of the body, as specified by the  ETagheader. | 
| void | setExpires(java.time.Instant expires)Set the date and time at which the message is no longer valid,
 as specified by the  Expiresheader. | 
| void | setExpires(long expires)Set the date and time at which the message is no longer valid,
 as specified by the  Expiresheader. | 
| void | setExpires(java.time.ZonedDateTime expires)Set the duration after which the message is no longer valid,
 as specified by the  Expiresheader. | 
| void | setHost(java.net.InetSocketAddress host)Set the (new) value of the  Hostheader. | 
| void | setIfMatch(java.util.List<java.lang.String> ifMatchList)Set the (new) value of the  If-Matchheader. | 
| void | setIfMatch(java.lang.String ifMatch)Set the (new) value of the  If-Matchheader. | 
| void | setIfModifiedSince(java.time.Instant ifModifiedSince)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setIfModifiedSince(long ifModifiedSince)Set the (new) value of the  If-Modified-Sinceheader. | 
| void | setIfModifiedSince(java.time.ZonedDateTime ifModifiedSince)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setIfNoneMatch(java.util.List<java.lang.String> ifNoneMatchList)Set the (new) values of the  If-None-Matchheader. | 
| void | setIfNoneMatch(java.lang.String ifNoneMatch)Set the (new) value of the  If-None-Matchheader. | 
| void | setIfUnmodifiedSince(java.time.Instant ifUnmodifiedSince)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setIfUnmodifiedSince(long ifUnmodifiedSince)Set the (new) value of the  If-Unmodified-Sinceheader. | 
| void | setIfUnmodifiedSince(java.time.ZonedDateTime ifUnmodifiedSince)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setInstant(java.lang.String headerName,
          java.time.Instant date)Set the given date under the given header name after formatting it as a string
 using the RFC-1123 date-time formatter. | 
| void | setLastModified(java.time.Instant lastModified)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setLastModified(long lastModified)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setLastModified(java.time.ZonedDateTime lastModified)Set the time the resource was last changed, as specified by the
  Last-Modifiedheader. | 
| void | setLocation(java.net.URI location)Set the (new) location of a resource,
 as specified by the  Locationheader. | 
| void | setOrigin(java.lang.String origin)Set the (new) value of the  Originheader. | 
| private void | setOrRemove(java.lang.String headerName,
           java.lang.String headerValue)Set the given header value, or remove the header if  null. | 
| void | setPragma(java.lang.String pragma)Set the (new) value of the  Pragmaheader. | 
| void | setRange(java.util.List<HttpRange> ranges)Sets the (new) value of the  Rangeheader. | 
| void | setUpgrade(java.lang.String upgrade)Set the (new) value of the  Upgradeheader. | 
| void | setVary(java.util.List<java.lang.String> requestHeaders)Set the request header names (e.g. | 
| void | setZonedDateTime(java.lang.String headerName,
                java.time.ZonedDateTime date)Set the given date under the given header name after formatting it as a string
 using the RFC-1123 date-time formatter. | 
| int | size() | 
| protected java.lang.String | toCommaDelimitedString(java.util.List<java.lang.String> headerValues)Turn the given list of header values into a comma-delimited result. | 
| java.util.Map<java.lang.String,java.lang.String> | toSingleValueMap()Return a  Mapwith the first values contained in thisMultiValueMap. | 
| java.lang.String | toString() | 
| java.util.Collection<java.util.List<java.lang.String>> | values() | 
| static HttpHeaders | writableHttpHeaders(HttpHeaders headers)Return an  HttpHeadersobject that can be read and written to. | 
private static final long serialVersionUID
public static final java.lang.String ACCEPT
Accept header field name.public static final java.lang.String ACCEPT_CHARSET
Accept-Charset header field name.public static final java.lang.String ACCEPT_ENCODING
Accept-Encoding header field name.public static final java.lang.String ACCEPT_LANGUAGE
Accept-Language header field name.public static final java.lang.String ACCEPT_RANGES
Accept-Ranges header field name.public static final java.lang.String ACCESS_CONTROL_ALLOW_CREDENTIALS
Access-Control-Allow-Credentials response header field name.public static final java.lang.String ACCESS_CONTROL_ALLOW_HEADERS
Access-Control-Allow-Headers response header field name.public static final java.lang.String ACCESS_CONTROL_ALLOW_METHODS
Access-Control-Allow-Methods response header field name.public static final java.lang.String ACCESS_CONTROL_ALLOW_ORIGIN
Access-Control-Allow-Origin response header field name.public static final java.lang.String ACCESS_CONTROL_EXPOSE_HEADERS
Access-Control-Expose-Headers response header field name.public static final java.lang.String ACCESS_CONTROL_MAX_AGE
Access-Control-Max-Age response header field name.public static final java.lang.String ACCESS_CONTROL_REQUEST_HEADERS
Access-Control-Request-Headers request header field name.public static final java.lang.String ACCESS_CONTROL_REQUEST_METHOD
Access-Control-Request-Method request header field name.public static final java.lang.String AGE
Age header field name.public static final java.lang.String ALLOW
Allow header field name.public static final java.lang.String AUTHORIZATION
Authorization header field name.public static final java.lang.String CACHE_CONTROL
Cache-Control header field name.public static final java.lang.String CONNECTION
Connection header field name.public static final java.lang.String CONTENT_ENCODING
Content-Encoding header field name.public static final java.lang.String CONTENT_DISPOSITION
Content-Disposition header field name.public static final java.lang.String CONTENT_LANGUAGE
Content-Language header field name.public static final java.lang.String CONTENT_LENGTH
Content-Length header field name.public static final java.lang.String CONTENT_LOCATION
Content-Location header field name.public static final java.lang.String CONTENT_RANGE
Content-Range header field name.public static final java.lang.String CONTENT_TYPE
Content-Type header field name.public static final java.lang.String COOKIE
Cookie header field name.public static final java.lang.String DATE
Date header field name.public static final java.lang.String ETAG
ETag header field name.public static final java.lang.String EXPECT
Expect header field name.public static final java.lang.String EXPIRES
Expires header field name.public static final java.lang.String FROM
From header field name.public static final java.lang.String HOST
Host header field name.public static final java.lang.String IF_MATCH
If-Match header field name.public static final java.lang.String IF_MODIFIED_SINCE
If-Modified-Since header field name.public static final java.lang.String IF_NONE_MATCH
If-None-Match header field name.public static final java.lang.String IF_RANGE
If-Range header field name.public static final java.lang.String IF_UNMODIFIED_SINCE
If-Unmodified-Since header field name.public static final java.lang.String LAST_MODIFIED
Last-Modified header field name.public static final java.lang.String LINK
Link header field name.public static final java.lang.String LOCATION
Location header field name.public static final java.lang.String MAX_FORWARDS
Max-Forwards header field name.public static final java.lang.String ORIGIN
Origin header field name.public static final java.lang.String PRAGMA
Pragma header field name.public static final java.lang.String PROXY_AUTHENTICATE
Proxy-Authenticate header field name.public static final java.lang.String PROXY_AUTHORIZATION
Proxy-Authorization header field name.public static final java.lang.String RANGE
Range header field name.public static final java.lang.String REFERER
Referer header field name.public static final java.lang.String RETRY_AFTER
Retry-After header field name.public static final java.lang.String SERVER
Server header field name.public static final java.lang.String SET_COOKIE
Set-Cookie header field name.public static final java.lang.String SET_COOKIE2
Set-Cookie2 header field name.public static final java.lang.String TE
TE header field name.public static final java.lang.String TRAILER
Trailer header field name.public static final java.lang.String TRANSFER_ENCODING
Transfer-Encoding header field name.public static final java.lang.String UPGRADE
Upgrade header field name.public static final java.lang.String USER_AGENT
User-Agent header field name.public static final java.lang.String VARY
Vary header field name.public static final java.lang.String VIA
Via header field name.public static final java.lang.String WARNING
Warning header field name.public static final java.lang.String WWW_AUTHENTICATE
WWW-Authenticate header field name.public static final HttpHeaders EMPTY
HttpHeaders instance (immutable).private static final java.util.regex.Pattern ETAG_HEADER_VALUE_PATTERN
private static final java.text.DecimalFormatSymbols DECIMAL_FORMAT_SYMBOLS
private static final java.time.ZoneId GMT
private static final java.time.format.DateTimeFormatter DATE_FORMATTER
private static final java.time.format.DateTimeFormatter[] DATE_PARSERS
final MultiValueMap<java.lang.String,java.lang.String> headers
public HttpHeaders()
HttpHeaders object.
 This is the common constructor, using a case-insensitive map structure.
public HttpHeaders(MultiValueMap<java.lang.String,java.lang.String> headers)
HttpHeaders instance backed by an existing map.
 This constructor is available as an optimization for adapting to existing headers map structures, primarily for internal use within the framework.
headers - the headers map (expected to operate with case-insensitive keys)public void setAccept(java.util.List<MediaType> acceptableMediaTypes)
Accept header.public java.util.List<MediaType> getAccept()
Accept header.
 Returns an empty list when the acceptable media types are unspecified.
public void setAcceptLanguage(java.util.List<java.util.Locale.LanguageRange> languages)
public java.util.List<java.util.Locale.LanguageRange> getAcceptLanguage()
If you only need sorted, preferred locales only use
 getAcceptLanguageAsLocales() or if you need to filter based on
 a list of supported locales you can pass the returned list to
 Locale.filter(List, Collection).
java.lang.IllegalArgumentException - if the value cannot be converted to a language rangepublic void setAcceptLanguageAsLocales(java.util.List<java.util.Locale> locales)
setAcceptLanguage(List) using Locale's.public java.util.List<java.util.Locale> getAcceptLanguageAsLocales()
java.lang.IllegalArgumentException - if the value cannot be converted to a localepublic void setAccessControlAllowCredentials(boolean allowCredentials)
Access-Control-Allow-Credentials response header.public boolean getAccessControlAllowCredentials()
Access-Control-Allow-Credentials response header.public void setAccessControlAllowHeaders(java.util.List<java.lang.String> allowedHeaders)
Access-Control-Allow-Headers response header.public java.util.List<java.lang.String> getAccessControlAllowHeaders()
Access-Control-Allow-Headers response header.public void setAccessControlAllowMethods(java.util.List<HttpMethod> allowedMethods)
Access-Control-Allow-Methods response header.public java.util.List<HttpMethod> getAccessControlAllowMethods()
Access-Control-Allow-Methods response header.public void setAccessControlAllowOrigin(@Nullable java.lang.String allowedOrigin)
Access-Control-Allow-Origin response header.@Nullable public java.lang.String getAccessControlAllowOrigin()
Access-Control-Allow-Origin response header.public void setAccessControlExposeHeaders(java.util.List<java.lang.String> exposedHeaders)
Access-Control-Expose-Headers response header.public java.util.List<java.lang.String> getAccessControlExposeHeaders()
Access-Control-Expose-Headers response header.public void setAccessControlMaxAge(java.time.Duration maxAge)
Access-Control-Max-Age response header.public void setAccessControlMaxAge(long maxAge)
Access-Control-Max-Age response header.public long getAccessControlMaxAge()
Access-Control-Max-Age response header.
 Returns -1 when the max age is unknown.
public void setAccessControlRequestHeaders(java.util.List<java.lang.String> requestHeaders)
Access-Control-Request-Headers request header.public java.util.List<java.lang.String> getAccessControlRequestHeaders()
Access-Control-Request-Headers request header.public void setAccessControlRequestMethod(@Nullable HttpMethod requestMethod)
Access-Control-Request-Method request header.@Nullable public HttpMethod getAccessControlRequestMethod()
Access-Control-Request-Method request header.public void setAcceptCharset(java.util.List<java.nio.charset.Charset> acceptableCharsets)
Accept-Charset header.public java.util.List<java.nio.charset.Charset> getAcceptCharset()
Accept-Charset header.public void setAllow(java.util.Set<HttpMethod> allowedMethods)
HTTP methods,
 as specified by the Allow header.public java.util.Set<HttpMethod> getAllow()
HTTP methods,
 as specified by the Allow header.
 Returns an empty set when the allowed methods are unspecified.
public void setBasicAuth(java.lang.String username,
                         java.lang.String password)
Note that this method only supports characters in the
 ISO-8859-1 character set.
username - the usernamepassword - the passwordjava.lang.IllegalArgumentException - if either user or
 password contain characters that cannot be encoded to ISO-8859-1setBasicAuth(String, String, Charset), 
RFC 7617public void setBasicAuth(java.lang.String username,
                         java.lang.String password,
                         @Nullable
                         java.nio.charset.Charset charset)
username - the usernamepassword - the passwordcharset - the charset to use to convert the credentials into an octet
 sequence. Defaults to ISO-8859-1.java.lang.IllegalArgumentException - if username or password
 contains characters that cannot be encoded to the given charsetpublic void setBearerAuth(java.lang.String token)
token - the Base64 encoded tokenpublic void setCacheControl(CacheControl cacheControl)
CacheControl instance as the
 new value of the Cache-Control header.public void setCacheControl(@Nullable java.lang.String cacheControl)
Cache-Control header.@Nullable public java.lang.String getCacheControl()
Cache-Control header.public void setConnection(java.lang.String connection)
Connection header.public void setConnection(java.util.List<java.lang.String> connection)
Connection header.public java.util.List<java.lang.String> getConnection()
Connection header.public void setContentDispositionFormData(java.lang.String name,
                                          @Nullable
                                          java.lang.String filename)
Content-Disposition header when creating a
 "multipart/form-data" request.
 Applications typically would not set this header directly but
 rather prepare a MultiValueMap<String, Object>, containing an
 Object or a Resource for each part,
 and then pass that to the RestTemplate or WebClient.
name - the control namefilename - the filename (may be null)getContentDisposition()public void setContentDisposition(ContentDisposition contentDisposition)
This could be used on a response to indicate if the content is expected to be displayed inline in the browser or as an attachment to be saved locally.
It can also be used for a "multipart/form-data" request.
 For more details see notes on setContentDispositionFormData(java.lang.String, java.lang.String).
getContentDisposition()public ContentDisposition getContentDisposition()
setContentDisposition(ContentDisposition)public void setContentLanguage(@Nullable java.util.Locale locale)
Locale of the content language,
 as specified by the Content-Language header.
 Use set(CONTENT_LANGUAGE, ...) if you need
 to set multiple content languages.
@Nullable public java.util.Locale getContentLanguage()
Locale of the content languages,
 as specified by the Content-Language header.
 Returns null when the content language is unknown.
 
Use getValuesAsList(CONTENT_LANGUAGE) if you need
 to get multiple content languages.
public void setContentLength(long contentLength)
Content-Length header.public long getContentLength()
Content-Length header.
 Returns -1 when the content-length is unknown.
public void setContentType(@Nullable MediaType mediaType)
Content-Type header.@Nullable public MediaType getContentType()
Content-Type header.
 Returns null when the content-type is unknown.
public void setDate(java.time.ZonedDateTime date)
Date header.public void setDate(java.time.Instant date)
Date header.public void setDate(long date)
Date header.
 The date should be specified as the number of milliseconds since January 1, 1970 GMT.
public long getDate()
Date header.
 The date is returned as the number of milliseconds since January 1, 1970 GMT. Returns -1 when the date is unknown.
java.lang.IllegalArgumentException - if the value cannot be converted to a datepublic void setETag(@Nullable java.lang.String etag)
ETag header.@Nullable public java.lang.String getETag()
ETag header.public void setExpires(java.time.ZonedDateTime expires)
Expires header.public void setExpires(java.time.Instant expires)
Expires header.public void setExpires(long expires)
Expires header.
 The date should be specified as the number of milliseconds since January 1, 1970 GMT.
public long getExpires()
Expires header.
 The date is returned as the number of milliseconds since January 1, 1970 GMT. Returns -1 when the date is unknown.
getFirstZonedDateTime(String)public void setHost(@Nullable java.net.InetSocketAddress host)
Host header.
 If the given port is 0,
 the host header will only contain the
 host name.
@Nullable public java.net.InetSocketAddress getHost()
Host header, if available.
 If the header value does not contain a port, the
 port in the returned address will
 be 0.
public void setIfMatch(java.lang.String ifMatch)
If-Match header.public void setIfMatch(java.util.List<java.lang.String> ifMatchList)
If-Match header.public java.util.List<java.lang.String> getIfMatch()
If-Match header.public void setIfModifiedSince(java.time.ZonedDateTime ifModifiedSince)
Last-Modified header.public void setIfModifiedSince(java.time.Instant ifModifiedSince)
Last-Modified header.public void setIfModifiedSince(long ifModifiedSince)
If-Modified-Since header.
 The date should be specified as the number of milliseconds since January 1, 1970 GMT.
public long getIfModifiedSince()
If-Modified-Since header.
 The date is returned as the number of milliseconds since January 1, 1970 GMT. Returns -1 when the date is unknown.
getFirstZonedDateTime(String)public void setIfNoneMatch(java.lang.String ifNoneMatch)
If-None-Match header.public void setIfNoneMatch(java.util.List<java.lang.String> ifNoneMatchList)
If-None-Match header.public java.util.List<java.lang.String> getIfNoneMatch()
If-None-Match header.public void setIfUnmodifiedSince(java.time.ZonedDateTime ifUnmodifiedSince)
Last-Modified header.public void setIfUnmodifiedSince(java.time.Instant ifUnmodifiedSince)
Last-Modified header.public void setIfUnmodifiedSince(long ifUnmodifiedSince)
If-Unmodified-Since header.
 The date should be specified as the number of milliseconds since January 1, 1970 GMT.
public long getIfUnmodifiedSince()
If-Unmodified-Since header.
 The date is returned as the number of milliseconds since January 1, 1970 GMT. Returns -1 when the date is unknown.
getFirstZonedDateTime(String)public void setLastModified(java.time.ZonedDateTime lastModified)
Last-Modified header.public void setLastModified(java.time.Instant lastModified)
Last-Modified header.public void setLastModified(long lastModified)
Last-Modified header.
 The date should be specified as the number of milliseconds since January 1, 1970 GMT.
public long getLastModified()
Last-Modified header.
 The date is returned as the number of milliseconds since January 1, 1970 GMT. Returns -1 when the date is unknown.
getFirstZonedDateTime(String)public void setLocation(@Nullable java.net.URI location)
Location header.@Nullable public java.net.URI getLocation()
Location header.
 Returns null when the location is unknown.
public void setOrigin(@Nullable java.lang.String origin)
Origin header.@Nullable public java.lang.String getOrigin()
Origin header.public void setPragma(@Nullable java.lang.String pragma)
Pragma header.@Nullable public java.lang.String getPragma()
Pragma header.public void setRange(java.util.List<HttpRange> ranges)
Range header.public java.util.List<HttpRange> getRange()
Range header.
 Returns an empty list when the range is unknown.
public void setUpgrade(@Nullable java.lang.String upgrade)
Upgrade header.@Nullable public java.lang.String getUpgrade()
Upgrade header.public void setVary(java.util.List<java.lang.String> requestHeaders)
requestHeaders - the request header namespublic java.util.List<java.lang.String> getVary()
public void setZonedDateTime(java.lang.String headerName,
                             java.time.ZonedDateTime date)
set(String, String) but for date headers.public void setInstant(java.lang.String headerName,
                       java.time.Instant date)
set(String, String) but for date headers.public void setDate(java.lang.String headerName,
                    long date)
set(String, String) but for date headers.setZonedDateTime(String, ZonedDateTime)public long getFirstDate(java.lang.String headerName)
IllegalArgumentException
 if the value cannot be parsed as a date.headerName - the header namegetFirstZonedDateTime(String)private long getFirstDate(java.lang.String headerName,
                          boolean rejectInvalid)
rejectInvalid=false), or raise IllegalArgumentException
 if the value cannot be parsed as a date.headerName - the header namerejectInvalid - whether to reject invalid values with an
 IllegalArgumentException (true) or rather return -1
 in that case (false)getFirstZonedDateTime(String, boolean)@Nullable public java.time.ZonedDateTime getFirstZonedDateTime(java.lang.String headerName)
null if there is no value, or raise IllegalArgumentException
 if the value cannot be parsed as a date.headerName - the header namenull if none@Nullable private java.time.ZonedDateTime getFirstZonedDateTime(java.lang.String headerName, boolean rejectInvalid)
null if there is no value or also in case of an invalid value
 (if rejectInvalid=false), or raise IllegalArgumentException
 if the value cannot be parsed as a date.headerName - the header namerejectInvalid - whether to reject invalid values with an
 IllegalArgumentException (true) or rather return null
 in that case (false)null if none (or invalid)public java.util.List<java.lang.String> getValuesAsList(java.lang.String headerName)
headerName - the header nameprotected java.util.List<java.lang.String> getETagValuesAsList(java.lang.String headerName)
headerName - the header name@Nullable protected java.lang.String getFieldValues(java.lang.String headerName)
headerName - the header nameprotected java.lang.String toCommaDelimitedString(java.util.List<java.lang.String> headerValues)
headerValues - the list of header valuesprivate void setOrRemove(java.lang.String headerName,
                         @Nullable
                         java.lang.String headerValue)
null.headerName - the header nameheaderValue - the header value, or null for none@Nullable public java.lang.String getFirst(java.lang.String headerName)
getFirst in interface MultiValueMap<java.lang.String,java.lang.String>headerName - the header namenull if nonepublic void add(java.lang.String headerName,
                @Nullable
                java.lang.String headerValue)
add in interface MultiValueMap<java.lang.String,java.lang.String>headerName - the header nameheaderValue - the header valuejava.lang.UnsupportedOperationException - if adding headers is not supportedput(String, List), 
set(String, String)public void addAll(java.lang.String key,
                   java.util.List<? extends java.lang.String> values)
MultiValueMapaddAll in interface MultiValueMap<java.lang.String,java.lang.String>key - they keyvalues - the values to be addedpublic void addAll(MultiValueMap<java.lang.String,java.lang.String> values)
MultiValueMapMultiValueMap to the current values.addAll in interface MultiValueMap<java.lang.String,java.lang.String>values - the values to be addedpublic void set(java.lang.String headerName,
                @Nullable
                java.lang.String headerValue)
set in interface MultiValueMap<java.lang.String,java.lang.String>headerName - the header nameheaderValue - the header valuejava.lang.UnsupportedOperationException - if adding headers is not supportedput(String, List), 
add(String, String)public void setAll(java.util.Map<java.lang.String,java.lang.String> values)
MultiValueMapsetAll in interface MultiValueMap<java.lang.String,java.lang.String>values - the values.public java.util.Map<java.lang.String,java.lang.String> toSingleValueMap()
MultiValueMapMap with the first values contained in this MultiValueMap.toSingleValueMap in interface MultiValueMap<java.lang.String,java.lang.String>public int size()
size in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public boolean isEmpty()
isEmpty in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public boolean containsKey(java.lang.Object key)
containsKey in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public boolean containsValue(java.lang.Object value)
containsValue in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>@Nullable public java.util.List<java.lang.String> get(java.lang.Object key)
get in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public java.util.List<java.lang.String> put(java.lang.String key,
                                            java.util.List<java.lang.String> value)
put in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public java.util.List<java.lang.String> remove(java.lang.Object key)
remove in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public void putAll(java.util.Map<? extends java.lang.String,? extends java.util.List<java.lang.String>> map)
putAll in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public void clear()
clear in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public java.util.Set<java.lang.String> keySet()
keySet in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public java.util.Collection<java.util.List<java.lang.String>> values()
values in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public java.util.Set<java.util.Map.Entry<java.lang.String,java.util.List<java.lang.String>>> entrySet()
entrySet in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>public boolean equals(java.lang.Object other)
equals in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>equals in class java.lang.Objectpublic int hashCode()
hashCode in interface java.util.Map<java.lang.String,java.util.List<java.lang.String>>hashCode in class java.lang.Objectpublic java.lang.String toString()
toString in class java.lang.Objectpublic static HttpHeaders readOnlyHttpHeaders(HttpHeaders headers)
HttpHeaders object that can only be read, not written to.public static HttpHeaders writableHttpHeaders(HttpHeaders headers)
HttpHeaders object that can be read and written to.public static java.lang.String formatHeaders(MultiValueMap<java.lang.String,java.lang.String> headers)
Map formatting that also uses commas between entries.headers - the headers to formatstatic java.lang.String formatDate(long date)