Class HeaderGroup

java.lang.Object
org.apache.http.message.HeaderGroup
All Implemented Interfaces:
Serializable, Cloneable

public class HeaderGroup extends Object implements Cloneable, Serializable
A class for combining a set of headers. This class allows for multiple headers with the same name and keeps track of the order in which headers were added.
Since:
4.0
See Also:
  • Constructor Details

    • HeaderGroup

      public HeaderGroup()
      Constructor for HeaderGroup.
  • Method Details

    • clear

      public void clear()
      Removes any contained headers.
    • addHeader

      public void addHeader(Header header)
      Adds the given header to the group. The order in which this header was added is preserved.
      Parameters:
      header - the header to add
    • removeHeader

      public void removeHeader(Header header)
      Removes the given header.
      Parameters:
      header - the header to remove
    • updateHeader

      public void updateHeader(Header header)
      Replaces the first occurence of the header with the same name. If no header with the same name is found the given header is added to the end of the list.
      Parameters:
      header - the new header that should replace the first header with the same name if present in the list.
    • setHeaders

      public void setHeaders(Header[] headers)
      Sets all of the headers contained within this group overriding any existing headers. The headers are added in the order in which they appear in the array.
      Parameters:
      headers - the headers to set
    • getCondensedHeader

      public Header getCondensedHeader(String name)
      Gets a header representing all of the header values with the given name. If more that one header with the given name exists the values will be combined with a "," as per RFC 2616.

      Header name comparison is case insensitive.

      Parameters:
      name - the name of the header(s) to get
      Returns:
      a header with a condensed value or null if no headers by the given name are present
    • getHeaders

      public Header[] getHeaders(String name)
      Gets all of the headers with the given name. The returned array maintains the relative order in which the headers were added.

      Header name comparison is case insensitive.

      Parameters:
      name - the name of the header(s) to get
      Returns:
      an array of length ≥ 0
    • getFirstHeader

      public Header getFirstHeader(String name)
      Gets the first header with the given name.

      Header name comparison is case insensitive.

      Parameters:
      name - the name of the header to get
      Returns:
      the first header or null
    • getLastHeader

      public Header getLastHeader(String name)
      Gets the last header with the given name.

      Header name comparison is case insensitive.

      Parameters:
      name - the name of the header to get
      Returns:
      the last header or null
    • getAllHeaders

      public Header[] getAllHeaders()
      Gets all of the headers contained within this group.
      Returns:
      an array of length ≥ 0
    • containsHeader

      public boolean containsHeader(String name)
      Tests if headers with the given name are contained within this group.

      Header name comparison is case insensitive.

      Parameters:
      name - the header name to test for
      Returns:
      true if at least one header with the name is contained, false otherwise
    • iterator

      public HeaderIterator iterator()
      Returns an iterator over this group of headers.
      Returns:
      iterator over this group of headers.
      Since:
      4.0
    • iterator

      public HeaderIterator iterator(String name)
      Returns an iterator over the headers with a given name in this group.
      Parameters:
      name - the name of the headers over which to iterate, or null for all headers
      Returns:
      iterator over some headers in this group.
      Since:
      4.0
    • copy

      public HeaderGroup copy()
      Returns a copy of this object
      Returns:
      copy of this object
      Since:
      4.0
    • clone

      public Object clone() throws CloneNotSupportedException
      Throws:
      CloneNotSupportedException
    • toString

      public String toString()
      Overrides:
      toString in class Object