Class DefaultHttpHeaders
- Direct Known Subclasses:
CombinedHttpHeaders
HttpHeaders.-
Nested Class Summary
Nested classes/interfaces inherited from class io.netty.handler.codec.http.HttpHeaders
HttpHeaders.Names, HttpHeaders.Values -
Field Summary
Fields inherited from class io.netty.handler.codec.http.HttpHeaders
EMPTY_HEADERS -
Constructor Summary
ConstructorsModifierConstructorDescriptionCreate a new, empty HTTP headers object.DefaultHttpHeaders(boolean validate) Deprecated.protectedDefaultHttpHeaders(boolean validateValues, io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator) Create an HTTP headers object with the given name validator.protectedDefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator, io.netty.handler.codec.DefaultHeaders.ValueValidator<CharSequence> valueValidator) Create an HTTP headers object with the given name and value validators.protectedDefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator, io.netty.handler.codec.DefaultHeaders.ValueValidator<CharSequence> valueValidator, int sizeHint) Create an HTTP headers object with the given name and value validators.protectedDefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders<CharSequence, CharSequence, ?> headers) -
Method Summary
Modifier and TypeMethodDescriptionadd(HttpHeaders headers) Adds all header entries of the specifiedheaders.add(CharSequence name, Iterable<?> values) Adds a new header with the specified name and values.add(CharSequence name, Object value) Adds a new header with the specified name and value.addInt(CharSequence name, int value) Add thenametovalue.addShort(CharSequence name, short value) Add thenametovalue.clear()Removes all headers from thisHttpMessage.booleancontains(CharSequence name) Checks to see if there is a header with the specified namebooleancontains(CharSequence name, CharSequence value, boolean ignoreCase) Returnstrueif a header with thenameandvalueexists,falseotherwise.booleanbooleancopy()Returns a deep copy of the passed inHttpHeaders.entries()Returns a newListthat contains all headers in this object.booleanget(CharSequence name) Returns the value of a header with the specified name.getAll(CharSequence name) Returns the values of headers with the specified namegetInt(CharSequence name) Returns the integer value of a header with the specified name.intgetInt(CharSequence name, int defaultValue) Returns the integer value of a header with the specified name.getShort(CharSequence name) Returns the short value of a header with the specified name.shortgetShort(CharSequence name, short defaultValue) Returns the short value of a header with the specified name.getTimeMillis(CharSequence name) Returns the date value of a header with the specified name.longgetTimeMillis(CharSequence name, long defaultValue) Returns the date value of a header with the specified name.inthashCode()booleanisEmpty()Checks if no header exists.iterator()Deprecated.names()Returns a newSetthat contains the names of all headers in this object.remove(CharSequence name) Removes the header with the specified name.set(HttpHeaders headers) Cleans the current header entries and copies all header entries of the specifiedheaders.set(CharSequence name, Iterable<?> values) Sets a header with the specified name and values.set(CharSequence name, Object value) Sets a header with the specified name and value.setInt(CharSequence name, int value) Set thenametovalue.setShort(CharSequence name, short value) Set thenametovalue.intsize()Returns the number of headers in this object.Equivalent toHttpHeaders.getAll(String)but it is possible that no intermediate list is generated.Equivalent toHttpHeaders.getAll(String)but it is possible that no intermediate list is generated.Methods inherited from class io.netty.handler.codec.http.HttpHeaders
addDateHeader, addDateHeader, addHeader, addHeader, addIntHeader, addIntHeader, clearHeaders, containsValue, encodeAscii, equalsIgnoreCase, get, getAllAsString, getAsString, getContentLength, getContentLength, getDate, getDate, getDateHeader, getDateHeader, getDateHeader, getDateHeader, getHeader, getHeader, getHeader, getHeader, getHost, getHost, getIntHeader, getIntHeader, getIntHeader, getIntHeader, is100ContinueExpected, isContentLengthSet, isKeepAlive, isTransferEncodingChunked, iteratorAsString, newEntity, removeHeader, removeHeader, removeTransferEncodingChunked, set100ContinueExpected, set100ContinueExpected, setAll, setContentLength, setDate, setDateHeader, setDateHeader, setDateHeader, setDateHeader, setHeader, setHeader, setHeader, setHeader, setHost, setHost, setIntHeader, setIntHeader, setIntHeader, setIntHeader, setKeepAlive, setTransferEncodingChunked, toStringMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.lang.Iterable
forEach, spliterator
-
Constructor Details
-
DefaultHttpHeaders
public DefaultHttpHeaders()Create a new, empty HTTP headers object.Header names and values are validated as they are added, to ensure they are compliant with the HTTP protocol.
-
DefaultHttpHeaders
Deprecated.Prefer using theDefaultHttpHeaders()constructor instead, to always have validation enabled.Warning! Settingvalidatetofalsewill mean that Netty won't validate invalid input: '&' protect against user-supplied header values that are malicious. This can leave your server implementation vulnerable to CWE-113: Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Response Splitting') . When disabling this validation, it is the responsibility of the caller to ensure that the values supplied do not contain a non-url-escaped carriage return (CR) and/or line feed (LF) characters.- Parameters:
validate- Should Netty validate header values to ensure they aren't malicious.
-
DefaultHttpHeaders
protected DefaultHttpHeaders(boolean validateValues, io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator) Create an HTTP headers object with the given name validator.Warning! It is strongly recommended that the name validator implement validation that is at least as strict as
HttpHeaderValidationUtil.validateToken(CharSequence). It is also strongly recommended thatvalidateValuesis enabled.Without these validations in place, your code can be susceptible to CWE-113: Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Response Splitting') . It is the responsibility of the caller to ensure that the values supplied do not contain a non-url-escaped carriage return (CR) and/or line feed (LF) characters.
- Parameters:
validateValues- Should Netty validate header values to ensure they aren't malicious.nameValidator- TheDefaultHeaders.NameValidatorto use, neverinvalid @code
{@code null.
-
DefaultHttpHeaders
protected DefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator, io.netty.handler.codec.DefaultHeaders.ValueValidator<CharSequence> valueValidator) Create an HTTP headers object with the given name and value validators.Warning! It is strongly recommended that the name validator implement validation that is at least as strict as
HttpHeaderValidationUtil.validateToken(CharSequence). And that the value validator is at least as strict asHttpHeaderValidationUtil.validateValidHeaderValue(CharSequence).Without these validations in place, your code can be susceptible to CWE-113: Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Response Splitting') . It is the responsibility of the caller to ensure that the values supplied do not contain a non-url-escaped carriage return (CR) and/or line feed (LF) characters.
- Parameters:
nameValidator- TheDefaultHeaders.NameValidatorto use, nevernull.valueValidator- TheDefaultHeaders.ValueValidatorto use, nevernull.
-
DefaultHttpHeaders
protected DefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders.NameValidator<CharSequence> nameValidator, io.netty.handler.codec.DefaultHeaders.ValueValidator<CharSequence> valueValidator, int sizeHint) Create an HTTP headers object with the given name and value validators.Warning! It is strongly recommended that the name validator implement validation that is at least as strict as
HttpHeaderValidationUtil.validateToken(CharSequence). And that the value validator is at least as strict asHttpHeaderValidationUtil.validateValidHeaderValue(CharSequence).Without these validations in place, your code can be susceptible to CWE-113: Improper Neutralization of CRLF Sequences in HTTP Headers ('HTTP Response Splitting') . It is the responsibility of the caller to ensure that the values supplied do not contain a non-url-escaped carriage return (CR) and/or line feed (LF) characters.
- Parameters:
nameValidator- TheDefaultHeaders.NameValidatorto use, nevernull.valueValidator- TheDefaultHeaders.ValueValidatorto use, nevernull.sizeHint- A hint about the anticipated number of entries.
-
DefaultHttpHeaders
protected DefaultHttpHeaders(io.netty.handler.codec.DefaultHeaders<CharSequence, CharSequence, ?> headers)
-
-
Method Details
-
add
Description copied from class:HttpHeadersAdds all header entries of the specifiedheaders.- Overrides:
addin classHttpHeaders- Returns:
this
-
set
Description copied from class:HttpHeadersCleans the current header entries and copies all header entries of the specifiedheaders.- Overrides:
setin classHttpHeaders- Returns:
this
-
add
- Specified by:
addin classHttpHeaders- See Also:
-
add
Description copied from class:HttpHeadersAdds a new header with the specified name and value. If the specified value is not aString, it is converted into aStringbyObject.toString(), except in the cases ofDateandCalendar, which are formatted to the date format defined in RFC2616.- Overrides:
addin classHttpHeaders- Parameters:
name- The name of the header being addedvalue- The value of the header being added- Returns:
this
-
add
- Specified by:
addin classHttpHeaders- See Also:
-
add
Description copied from class:HttpHeadersAdds a new header with the specified name and values. This getMethod can be represented approximately as the following code:for (Object v: values) { if (v == null) { break; } headers.add(name, v); }- Overrides:
addin classHttpHeaders- Parameters:
name- The name of the headers being setvalues- The values of the headers being set- Returns:
this
-
addInt
Description copied from class:HttpHeadersAdd thenametovalue.- Specified by:
addIntin classHttpHeaders- Parameters:
name- The name to modifyvalue- The value- Returns:
this
-
addShort
Description copied from class:HttpHeadersAdd thenametovalue.- Specified by:
addShortin classHttpHeaders- Parameters:
name- The name to modifyvalue- The value- Returns:
this
-
remove
- Specified by:
removein classHttpHeaders- See Also:
-
remove
Description copied from class:HttpHeadersRemoves the header with the specified name.- Overrides:
removein classHttpHeaders- Parameters:
name- The name of the header to remove- Returns:
this
-
set
- Specified by:
setin classHttpHeaders- See Also:
-
set
Description copied from class:HttpHeadersSets a header with the specified name and value. If there is an existing header with the same name, it is removed. If the specified value is not aString, it is converted into aStringbyObject.toString(), except forDateandCalendar, which are formatted to the date format defined in RFC2616.- Overrides:
setin classHttpHeaders- Parameters:
name- The name of the header being setvalue- The value of the header being set- Returns:
this
-
set
- Specified by:
setin classHttpHeaders- See Also:
-
set
Description copied from class:HttpHeadersSets a header with the specified name and values. If there is an existing header with the same name, it is removed. This getMethod can be represented approximately as the following code:headers.remove(name); for (Object v: values) { if (v == null) { break; } headers.add(name, v); }- Overrides:
setin classHttpHeaders- Parameters:
name- The name of the headers being setvalues- The values of the headers being set- Returns:
this
-
setInt
Description copied from class:HttpHeadersSet thenametovalue. This will remove all previous values associated withname.- Specified by:
setIntin classHttpHeaders- Parameters:
name- The name to modifyvalue- The value- Returns:
this
-
setShort
Description copied from class:HttpHeadersSet thenametovalue. This will remove all previous values associated withname.- Specified by:
setShortin classHttpHeaders- Parameters:
name- The name to modifyvalue- The value- Returns:
this
-
clear
Description copied from class:HttpHeadersRemoves all headers from thisHttpMessage.- Specified by:
clearin classHttpHeaders- Returns:
this
-
get
- Specified by:
getin classHttpHeaders- See Also:
-
get
Description copied from class:HttpHeadersReturns the value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Overrides:
getin classHttpHeaders- Parameters:
name- The name of the header to search- Returns:
- The first header value or
nullif there is no such header - See Also:
-
getInt
Description copied from class:HttpHeadersReturns the integer value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getIntin classHttpHeaders- Parameters:
name- the name of the header to search- Returns:
- the first header value if the header is found and its value is an integer.
nullif there's no such header or its value is not an integer.
-
getInt
Description copied from class:HttpHeadersReturns the integer value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getIntin classHttpHeaders- Parameters:
name- the name of the header to searchdefaultValue- the default value- Returns:
- the first header value if the header is found and its value is an integer.
defaultValueif there's no such header or its value is not an integer.
-
getShort
Description copied from class:HttpHeadersReturns the short value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getShortin classHttpHeaders- Parameters:
name- the name of the header to search- Returns:
- the first header value if the header is found and its value is a short.
nullif there's no such header or its value is not a short.
-
getShort
Description copied from class:HttpHeadersReturns the short value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getShortin classHttpHeaders- Parameters:
name- the name of the header to searchdefaultValue- the default value- Returns:
- the first header value if the header is found and its value is a short.
defaultValueif there's no such header or its value is not a short.
-
getTimeMillis
Description copied from class:HttpHeadersReturns the date value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getTimeMillisin classHttpHeaders- Parameters:
name- the name of the header to search- Returns:
- the first header value if the header is found and its value is a date.
nullif there's no such header or its value is not a date.
-
getTimeMillis
Description copied from class:HttpHeadersReturns the date value of a header with the specified name. If there are more than one values for the specified name, the first value is returned.- Specified by:
getTimeMillisin classHttpHeaders- Parameters:
name- the name of the header to searchdefaultValue- the default value- Returns:
- the first header value if the header is found and its value is a date.
defaultValueif there's no such header or its value is not a date.
-
getAll
- Specified by:
getAllin classHttpHeaders- See Also:
-
getAll
Description copied from class:HttpHeadersReturns the values of headers with the specified name- Overrides:
getAllin classHttpHeaders- Parameters:
name- The name of the headers to search- Returns:
- A
Listof header values which will be empty if no values are found - See Also:
-
entries
Description copied from class:HttpHeadersReturns a newListthat contains all headers in this object. Note that modifying the returnedListwill not affect the state of this object. If you intend to enumerate over the header entries only, useHttpHeaders.iterator()instead, which has much less overhead.- Specified by:
entriesin classHttpHeaders- See Also:
-
iterator
Deprecated. -
iteratorCharSequence
- Specified by:
iteratorCharSequencein classHttpHeaders- Returns:
- Iterator over the name/value header pairs.
-
valueStringIterator
Description copied from class:HttpHeadersEquivalent toHttpHeaders.getAll(String)but it is possible that no intermediate list is generated.- Overrides:
valueStringIteratorin classHttpHeaders- Parameters:
name- the name of the header to retrieve- Returns:
- an
Iteratorof header values corresponding toname.
-
valueCharSequenceIterator
Description copied from class:HttpHeadersEquivalent toHttpHeaders.getAll(String)but it is possible that no intermediate list is generated.- Overrides:
valueCharSequenceIteratorin classHttpHeaders- Parameters:
name- the name of the header to retrieve- Returns:
- an
Iteratorof header values corresponding toname.
-
contains
- Specified by:
containsin classHttpHeaders- See Also:
-
contains
Description copied from class:HttpHeadersChecks to see if there is a header with the specified name- Overrides:
containsin classHttpHeaders- Parameters:
name- The name of the header to search for- Returns:
- True if at least one header is found
-
isEmpty
public boolean isEmpty()Description copied from class:HttpHeadersChecks if no header exists.- Specified by:
isEmptyin classHttpHeaders
-
size
public int size()Description copied from class:HttpHeadersReturns the number of headers in this object.- Specified by:
sizein classHttpHeaders
-
contains
- Overrides:
containsin classHttpHeaders- See Also:
-
contains
Description copied from class:HttpHeadersReturnstrueif a header with thenameandvalueexists,falseotherwise.If
ignoreCaseistruethen a case insensitive compare is done on the value.- Overrides:
containsin classHttpHeaders- Parameters:
name- the name of the header to findvalue- the value of the header to findignoreCase-truethen a case insensitive compare is run to compare values. otherwise a case sensitive compare is run to compare values.
-
names
Description copied from class:HttpHeadersReturns a newSetthat contains the names of all headers in this object. Note that modifying the returnedSetwill not affect the state of this object. If you intend to enumerate over the header entries only, useHttpHeaders.iterator()instead, which has much less overhead.- Specified by:
namesin classHttpHeaders
-
equals
-
hashCode
public int hashCode() -
copy
Description copied from class:HttpHeadersReturns a deep copy of the passed inHttpHeaders.- Overrides:
copyin classHttpHeaders
-
DefaultHttpHeaders()constructor instead, to always have validation enabled.