public abstract class HttpMethodBase extends Object implements HttpMethod
At minimum, subclasses will need to override:
getName() to return the approriate name for this method
   When a method requires additional request headers, subclasses will typically want to override:
addRequestHeaders(HttpState,HttpConnection)
      to write those headers
   When a method expects specific response headers, subclasses may want to override:
processResponseHeaders(HttpState,HttpConnection)
     to handle those headers
   | Modifier and Type | Field and Description | 
|---|---|
| protected HttpVersion | effectiveVersionHTTP protocol version used for execution of this method. | 
| protected StatusLine | statusLineThe Status-Line from the response. | 
| Constructor and Description | 
|---|
| HttpMethodBase()No-arg constructor. | 
| HttpMethodBase(String uri)Constructor specifying a URI. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | abort()Aborts the execution of this method. | 
| protected void | addCookieRequestHeader(HttpState state,
                      HttpConnection conn)Generates Cookie request headers for those  cookies
 that match the given host, port and path. | 
| protected void | addHostRequestHeader(HttpState state,
                    HttpConnection conn)Generates Host request header, as long as no Host request
 header already exists. | 
| protected void | addProxyConnectionHeader(HttpState state,
                        HttpConnection conn)Generates Proxy-Connection: Keep-Alive request header when 
 communicating via a proxy server. | 
| void | addRequestHeader(Header header)Adds the specified request header, NOT overwriting any previous value. | 
| void | addRequestHeader(String headerName,
                String headerValue)Adds the specified request header, NOT overwriting any previous value. | 
| protected void | addRequestHeaders(HttpState state,
                 HttpConnection conn)Generates all the required request  headers 
 to be submitted via the givenconnection. | 
| void | addResponseFooter(Header footer)Use this method internally to add footers. | 
| protected void | addUserAgentRequestHeader(HttpState state,
                         HttpConnection conn)Generates default User-Agent request header, as long as no
 User-Agent request header already exists. | 
| protected void | checkNotUsed() | 
| protected void | checkUsed() | 
| int | execute(HttpState state,
       HttpConnection conn)Executes this method using the specified  HttpConnectionandHttpState. | 
| protected static String | generateRequestLine(HttpConnection connection,
                   String name,
                   String requestPath,
                   String query,
                   String version)Generates HTTP request line according to the specified attributes. | 
| String | getAuthenticationRealm()Deprecated. 
 use #getHostAuthState() | 
| protected String | getContentCharSet(Header contentheader)Returns the character set from the Content-Type header. | 
| boolean | getDoAuthentication()Returns true if the HTTP method should automatically handle HTTP 
 authentication challenges (status code 401, etc.), false otherwise | 
| HttpVersion | getEffectiveVersion()Returns the HTTP version used with this method (may be null
 if undefined, that is, the method has not been executed) | 
| boolean | getFollowRedirects()Returns true if the HTTP method should automatically follow HTTP redirects 
 (status code 302, etc.), false otherwise. | 
| AuthState | getHostAuthState()Returns the target host  authentication state | 
| HostConfiguration | getHostConfiguration()Deprecated. 
 no longer applicable | 
| MethodRetryHandler | getMethodRetryHandler()Deprecated. 
 use  HttpMethodParams | 
| abstract String | getName()Obtains the name of the HTTP method as used in the HTTP request line,
 for example "GET" or "POST". | 
| HttpMethodParams | getParams()Returns  HTTP protocol parametersassociated with this method. | 
| String | getPath()Gets the path of this HTTP method. | 
| String | getProxyAuthenticationRealm()Deprecated. 
 use #getProxyAuthState() | 
| AuthState | getProxyAuthState()Returns the proxy  authentication state | 
| String | getQueryString()Gets the query string of this HTTP method. | 
| int | getRecoverableExceptionCount()Deprecated. 
 no longer used
 
 Returns the number of "recoverable" exceptions thrown and handled, to
 allow for monitoring the quality of the connection. | 
| String | getRequestCharSet()Returns the character encoding of the request from the Content-Type header. | 
| Header | getRequestHeader(String headerName)Returns the specified request header. | 
| protected HeaderGroup | getRequestHeaderGroup()Gets the  header groupstoring the request headers. | 
| Header[] | getRequestHeaders()Returns an array of the requests headers that the HTTP method currently has | 
| Header[] | getRequestHeaders(String headerName)Returns the request headers with the given name. | 
| byte[] | getResponseBody()Returns the response body of the HTTP method, if any, as an array of bytes. | 
| byte[] | getResponseBody(int maxlen)Returns the response body of the HTTP method, if any, as an array of bytes. | 
| InputStream | getResponseBodyAsStream()Returns the response body of the HTTP method, if any, as an  InputStream. | 
| String | getResponseBodyAsString()Returns the response body of the HTTP method, if any, as a  String. | 
| String | getResponseBodyAsString(int maxlen)Returns the response body of the HTTP method, if any, as a  String. | 
| String | getResponseCharSet()Returns the character encoding of the response from the Content-Type header. | 
| long | getResponseContentLength()Return the length (in bytes) of the response body, as specified in a
 Content-Length header. | 
| Header | getResponseFooter(String footerName)Gets the response footer associated with the given name. | 
| Header[] | getResponseFooters()Returns an array of the response footers that the HTTP method currently has
 in the order in which they were read. | 
| Header | getResponseHeader(String headerName)Gets the response header associated with the given name. | 
| protected HeaderGroup | getResponseHeaderGroup()Gets the  header groupstoring the response headers. | 
| Header[] | getResponseHeaders()Returns an array of the response headers that the HTTP method currently has
 in the order in which they were read. | 
| Header[] | getResponseHeaders(String headerName)Returns the response headers with the given name. | 
| protected InputStream | getResponseStream()Returns a stream from which the body of the current response may be read. | 
| protected HeaderGroup | getResponseTrailerHeaderGroup()Gets the  header groupstoring the response trailer headers 
 as per RFC 2616 section 3.6.1. | 
| int | getStatusCode()Returns the response status code. | 
| StatusLine | getStatusLine()Provides access to the response status line. | 
| String | getStatusText()Returns the status text (or "reason phrase") associated with the latest
 response. | 
| URI | getURI()Returns the URI of the HTTP method | 
| boolean | hasBeenUsed() | 
| boolean | isAborted()Tests whether the execution of this method has been aborted | 
| protected boolean | isConnectionCloseForced()Tests if the connection should be force-closed when no longer needed. | 
| boolean | isHttp11()Deprecated. 
 | 
| boolean | isRequestSent()Returns true if the HTTP has been transmitted to the target
 server in its entirety, false otherwise. | 
| boolean | isStrictMode()Deprecated. 
 Use  HttpParams.setParameter(String, Object)to exercise a more granular control over HTTP protocol strictness. | 
| protected void | processCookieHeaders(CookieSpec parser,
                    Header[] headers,
                    HttpState state,
                    HttpConnection conn)This method processes the specified cookie headers. | 
| protected void | processResponseBody(HttpState state,
                   HttpConnection conn)This method is invoked immediately after 
  readResponseBody(HttpState,HttpConnection)and can be overridden by
 sub-classes in order to provide custom body processing. | 
| protected void | processResponseHeaders(HttpState state,
                      HttpConnection conn)This method is invoked immediately after 
  readResponseHeaders(HttpState,HttpConnection)and can be overridden by
 sub-classes in order to provide custom response headers processing. | 
| protected void | processStatusLine(HttpState state,
                 HttpConnection conn)This method is invoked immediately after 
  readStatusLine(HttpState,HttpConnection)and can be overridden by
 sub-classes in order to provide custom response status line processing. | 
| protected void | readResponse(HttpState state,
            HttpConnection conn)Reads the response from the given  connection. | 
| protected void | readResponseBody(HttpState state,
                HttpConnection conn)Read the response body from the given  HttpConnection. | 
| protected void | readResponseHeaders(HttpState state,
                   HttpConnection conn)Reads the response headers from the given  connection. | 
| protected void | readStatusLine(HttpState state,
              HttpConnection conn) | 
| void | recycle()Deprecated. 
 no longer supported and will be removed in the future
             version of HttpClient | 
| void | releaseConnection()Releases the connection being used by this HTTP method. | 
| void | removeRequestHeader(Header header)Removes the given request header. | 
| void | removeRequestHeader(String headerName)Remove the request header associated with the given name. | 
| protected void | responseBodyConsumed()A response has been consumed. | 
| protected void | setConnectionCloseForced(boolean b)Sets whether or not the connection should be force-closed when no longer 
 needed. | 
| void | setDoAuthentication(boolean doAuthentication)Sets whether or not the HTTP method should automatically handle HTTP 
 authentication challenges (status code 401, etc.) | 
| void | setFollowRedirects(boolean followRedirects)Sets whether or not the HTTP method should automatically follow HTTP redirects 
 (status code 302, etc.) | 
| void | setHostConfiguration(HostConfiguration hostconfig)Deprecated. 
 no longer applicable | 
| void | setHttp11(boolean http11)Deprecated. 
 | 
| void | setMethodRetryHandler(MethodRetryHandler handler)Deprecated. 
 use  HttpMethodParams | 
| void | setParams(HttpMethodParams params)Assigns  HTTP protocol parametersfor this method. | 
| void | setPath(String path)Sets the path of the HTTP method. | 
| void | setQueryString(NameValuePair[] params)Sets the query string of this HTTP method. | 
| void | setQueryString(String queryString)Sets the query string of this HTTP method. | 
| void | setRequestHeader(Header header)Sets the specified request header, overwriting any previous value. | 
| void | setRequestHeader(String headerName,
                String headerValue)Set the specified request header, overwriting any previous value. | 
| protected void | setResponseStream(InputStream responseStream)Sets the response stream. | 
| void | setStrictMode(boolean strictMode)Deprecated. 
 Use  HttpParams.setParameter(String, Object)to exercise a more granular control over HTTP protocol strictness. | 
| void | setURI(URI uri)Sets the URI for this method. | 
| protected boolean | shouldCloseConnection(HttpConnection conn)Tests if the connection should be closed after the method has been executed. | 
| boolean | validate()Returns true the method is ready to execute, false otherwise. | 
| protected void | writeRequest(HttpState state,
            HttpConnection conn)
 Sends the request via the given  connection. | 
| protected boolean | writeRequestBody(HttpState state,
                HttpConnection conn)Writes the request body to the given  connection. | 
| protected void | writeRequestHeaders(HttpState state,
                   HttpConnection conn)Writes the request headers to the given  connection. | 
| protected void | writeRequestLine(HttpState state,
                HttpConnection conn)Writes the request line to the given  connection. | 
protected StatusLine statusLine
protected HttpVersion effectiveVersion
public HttpMethodBase()
public HttpMethodBase(String uri) throws IllegalArgumentException, IllegalStateException
uri - either an absolute or relative URI. The URI is expected
            to be URL-encodedIllegalArgumentException - when URI is invalidIllegalStateException - when protocol of the absolute URI is not recognisedpublic abstract String getName()
getName in interface HttpMethodpublic URI getURI() throws URIException
getURI in interface HttpMethodURIException - If the URI cannot be created.HttpMethod.getURI()public void setURI(URI uri) throws URIException
setURI in interface HttpMethoduri - URI to be setURIException - if a URI cannot be setpublic void setFollowRedirects(boolean followRedirects)
setFollowRedirects in interface HttpMethodfollowRedirects - true if the method will automatically follow redirects,
 false otherwise.public boolean getFollowRedirects()
getFollowRedirects in interface HttpMethodpublic void setHttp11(boolean http11)
HttpMethodParams.setVersion(HttpVersion)http11 - true to use HTTP/1.1, false to use 1.0public boolean getDoAuthentication()
getDoAuthentication in interface HttpMethodHttpMethod.setDoAuthentication(boolean)public void setDoAuthentication(boolean doAuthentication)
setDoAuthentication in interface HttpMethoddoAuthentication - true to process authentication challenges
 authomatically, false otherwise.HttpMethod.getDoAuthentication()public boolean isHttp11()
HttpMethodParams.getVersion()public void setPath(String path)
setPath in interface HttpMethodpath - the path of the HTTP method. The path is expected
        to be URL-encodedpublic void addRequestHeader(Header header)
addRequestHeader in interface HttpMethodheader - the header to add to the requestHttpMethod.addRequestHeader(String,String), 
HttpMethod.getRequestHeader(String), 
HttpMethod.removeRequestHeader(String)public void addResponseFooter(Header footer)
addResponseFooter in interface HttpMethodfooter - The footer to add.public String getPath()
getPath in interface HttpMethodpublic void setQueryString(String queryString)
setQueryString in interface HttpMethodqueryString - the query stringEncodingUtil.formUrlEncode(NameValuePair[], String)public void setQueryString(NameValuePair[] params)
setQueryString in interface HttpMethodparams - an array of NameValuePairs to add as query string
        parameters. The name/value pairs will be automcatically 
        URL encodedEncodingUtil.formUrlEncode(NameValuePair[], String), 
setQueryString(String)public String getQueryString()
getQueryString in interface HttpMethodHttpMethod.setQueryString(NameValuePair[]), 
HttpMethod.setQueryString(String)public void setRequestHeader(String headerName, String headerValue)
setRequestHeader in interface HttpMethodheaderName - the header's nameheaderValue - the header's valueHttpMethod.setRequestHeader(Header), 
HttpMethod.getRequestHeader(String), 
HttpMethod.removeRequestHeader(String)public void setRequestHeader(Header header)
setRequestHeader in interface HttpMethodheader - the headerHttpMethod.setRequestHeader(String,String), 
HttpMethod.getRequestHeader(String), 
HttpMethod.removeRequestHeader(String)public Header getRequestHeader(String headerName)
getRequestHeader in interface HttpMethodheaderName - The name of the header to be returned.public Header[] getRequestHeaders()
getRequestHeaders in interface HttpMethodHttpMethod.addRequestHeader(Header), 
HttpMethod.addRequestHeader(String,String)public Header[] getRequestHeaders(String headerName)
HttpMethodgetRequestHeaders in interface HttpMethodheaderName - the name of the headers to be returned.HttpMethod.getRequestHeaders(java.lang.String)protected HeaderGroup getRequestHeaderGroup()
header group storing the request headers.protected HeaderGroup getResponseTrailerHeaderGroup()
header group storing the response trailer headers 
 as per RFC 2616 section 3.6.1.protected HeaderGroup getResponseHeaderGroup()
header group storing the response headers.public Header[] getResponseHeaders(String headerName)
HttpMethodgetResponseHeaders in interface HttpMethodheaderName - the name of the headers to be returned.HttpMethod.getResponseHeaders(java.lang.String)public int getStatusCode()
getStatusCode in interface HttpMethodpublic StatusLine getStatusLine()
getStatusLine in interface HttpMethodpublic Header[] getResponseHeaders()
getResponseHeaders in interface HttpMethodpublic Header getResponseHeader(String headerName)
getResponseHeader in interface HttpMethodheaderName - the header name to matchpublic long getResponseContentLength()
Return -1 when the content-length is unknown.
public byte[] getResponseBody()
                       throws IOException
getResponseBody in interface HttpMethodIOException - If an I/O (transport) problem occurs while obtaining the 
 response body.public byte[] getResponseBody(int maxlen)
                       throws IOException
 
 If the response is large this method involves lots of array copying and many object 
 allocations, which makes it unsuitable for high-performance / low-footprint applications.
 Those applications should use getResponseBodyAsStream().
maxlen - the maximum content length to accept (number of bytes).IOException - If an I/O (transport) problem occurs while obtaining the 
 response body.public InputStream getResponseBodyAsStream() throws IOException
InputStream. 
 If response body is not available, returns null. If the response has been
 buffered this method returns a new stream object on every call. If the response
 has not been buffered the returned stream can only be read once.getResponseBodyAsStream in interface HttpMethodnull.IOException - If an I/O (transport) problem occurs while obtaining the 
 response body.public String getResponseBodyAsString() throws IOException
String. 
 If response body is not available or cannot be read, returns null
 The string conversion on the data is done using the character encoding specified
 in Content-Type header. Buffers the response and this method can be 
 called several times yielding the same result each time.
 
 Note: This will cause the entire response body to be buffered in memory. A
 malicious server may easily exhaust all the VM memory. It is strongly
 recommended, to use getResponseAsStream if the content length of the response
 is unknown or resonably large.getResponseBodyAsString in interface HttpMethodnull.IOException - If an I/O (transport) problem occurs while obtaining the 
 response body.public String getResponseBodyAsString(int maxlen) throws IOException
String. 
 If response body is not available or cannot be read, returns null
 The string conversion on the data is done using the character encoding specified
 in Content-Type header. Buffers the response and this method can be 
 called several times yielding the same result each time.
 
 Note: This will cause the entire response body to be buffered in memory. This method is
 safe if the content length of the response is unknown, because the amount of memory used
 is limited.
 
 If the response is large this method involves lots of array copying and many object 
 allocations, which makes it unsuitable for high-performance / low-footprint applications.
 Those applications should use getResponseBodyAsStream().
maxlen - the maximum content length to accept (number of bytes). Note that,
 depending on the encoding, this is not equal to the number of characters.null.IOException - If an I/O (transport) problem occurs while obtaining the 
 response body.public Header[] getResponseFooters()
getResponseFooters in interface HttpMethodpublic Header getResponseFooter(String footerName)
getResponseFooter in interface HttpMethodfooterName - the footer name to matchprotected void setResponseStream(InputStream responseStream)
responseStream - The new response stream.protected InputStream getResponseStream()
responseBodyConsumed
 has been called, or if the stream returned by a previous call has been closed,
 null will be returned.public String getStatusText()
getStatusText in interface HttpMethodpublic void setStrictMode(boolean strictMode)
HttpParams.setParameter(String, Object)
 to exercise a more granular control over HTTP protocol strictness.setStrictMode in interface HttpMethodstrictMode - true for strict mode, false otherwiseHttpMethod.isStrictMode()public boolean isStrictMode()
HttpParams.setParameter(String, Object)
 to exercise a more granular control over HTTP protocol strictness.HttpMethodisStrictMode in interface HttpMethodHttpMethod.setStrictMode(boolean)public void addRequestHeader(String headerName, String headerValue)
addRequestHeader in interface HttpMethodheaderName - the header's nameheaderValue - the header's valueHttpMethod.addRequestHeader(Header), 
HttpMethod.getRequestHeader(String), 
HttpMethod.removeRequestHeader(String)protected boolean isConnectionCloseForced()
true if the connection must be closedprotected void setConnectionCloseForced(boolean b)
true in abnormal 
 circumstances, such as HTTP protocol violations.b - true if the connection must be closed, false
 otherwise.protected boolean shouldCloseConnection(HttpConnection conn)
conn - the connection in questionpublic int execute(HttpState state, HttpConnection conn) throws HttpException, IOException
HttpConnection and
 HttpState.execute in interface HttpMethodstate - state information to associate with this
        request. Must be non-null.conn - the connection to used to execute
        this HTTP method. Must be non-null.IOException - if an I/O (transport) error occursHttpException - if a protocol exception occurs.public void abort()
abort in interface HttpMethodHttpMethod.execute(HttpState, HttpConnection)public boolean hasBeenUsed()
hasBeenUsed in interface HttpMethodpublic void recycle()
recycle in interface HttpMethodreleaseConnection()public void releaseConnection()
releaseConnection in interface HttpMethodpublic void removeRequestHeader(String headerName)
removeRequestHeader in interface HttpMethodheaderName - the header namepublic void removeRequestHeader(Header header)
removeRequestHeader in interface HttpMethodheader - the headerpublic boolean validate()
validate in interface HttpMethodprotected void addCookieRequestHeader(HttpState state, HttpConnection conn) throws IOException, HttpException
cookies
 that match the given host, port and path.state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void addHostRequestHeader(HttpState state, HttpConnection conn) throws IOException, HttpException
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void addProxyConnectionHeader(HttpState state, HttpConnection conn) throws IOException, HttpException
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void addRequestHeaders(HttpState state, HttpConnection conn) throws IOException, HttpException
headers 
 to be submitted via the given connection.
 This implementation adds User-Agent, Host, Cookie, Authorization, Proxy-Authorization and Proxy-Connection headers, when appropriate.
Subclasses may want to override this method to to add additional headers, and may choose to invoke this implementation (via super) to add the "standard" headers.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.writeRequestHeaders(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void addUserAgentRequestHeader(HttpState state, HttpConnection conn) throws IOException, HttpException
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void checkNotUsed()
                     throws IllegalStateException
IllegalStateException - if the method has been used and not
      recycledprotected void checkUsed()
                  throws IllegalStateException
IllegalStateException - if not usedprotected static String generateRequestLine(HttpConnection connection, String name, String requestPath, String query, String version)
connection - the connection used to execute
        this HTTP methodname - the method name generate a request forrequestPath - the path string for the requestquery - the query string for the requestversion - the protocol version to use (e.g. HTTP/1.0)protected void processResponseBody(HttpState state, HttpConnection conn)
readResponseBody(HttpState,HttpConnection) and can be overridden by
 sub-classes in order to provide custom body processing.
 This implementation does nothing.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodreadResponse(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
readResponseBody(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void processResponseHeaders(HttpState state, HttpConnection conn)
readResponseHeaders(HttpState,HttpConnection) and can be overridden by
 sub-classes in order to provide custom response headers processing.
 
 This implementation will handle the Set-Cookie and
 Set-Cookie2 headers, if any, adding the relevant cookies to
 the given HttpState.
 
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodreadResponse(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
readResponseHeaders(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void processCookieHeaders(CookieSpec parser, Header[] headers, HttpState state, HttpConnection conn)
processResponseHeaders(HttpState,HttpConnection)headers - cookie Headers to be processedstate - the state information associated with
        this HTTP methodconn - the connection used to execute
        this HTTP methodprotected void processStatusLine(HttpState state, HttpConnection conn)
readStatusLine(HttpState,HttpConnection) and can be overridden by
 sub-classes in order to provide custom response status line processing.state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodreadResponse(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
readStatusLine(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void readResponse(HttpState state, HttpConnection conn) throws IOException, HttpException
connection.
 The response is processed as the following sequence of actions:
readStatusLine(HttpState,HttpConnection) is
 invoked to read the request line.
 processStatusLine(HttpState,HttpConnection)
 is invoked, allowing the method to process the status line if
 desired.
 readResponseHeaders(HttpState,HttpConnection) is invoked to read
 the associated headers.
 processResponseHeaders(HttpState,HttpConnection) is invoked, allowing
 the method to process the headers if desired.
 readResponseBody(HttpState,HttpConnection) is
 invoked to read the associated body (if any).
 processResponseBody(HttpState,HttpConnection) is invoked, allowing the
 method to process the response body if desired.
 state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void readResponseBody(HttpState state, HttpConnection conn) throws IOException, HttpException
HttpConnection.
 The current implementation wraps the socket level stream with an appropriate stream for the type of response (chunked, content-length, or auto-close). If there is no response body, the connection associated with the request will be returned to the connection manager.
Subclasses may want to override this method to to customize the processing.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.readResponse(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
processResponseBody(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void readResponseHeaders(HttpState state, HttpConnection conn) throws IOException, HttpException
connection.
 Subclasses may want to override this method to to customize the processing.
"It must be possible to combine the multiple header fields into one "field-name: field-value" pair, without changing the semantics of the message, by appending each subsequent field-value to the first, each separated by a comma." - HTTP/1.0 (4.3)
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.readResponse(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
processResponseHeaders(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection)protected void readStatusLine(HttpState state, HttpConnection conn) throws IOException, HttpException
HttpConnection, setting my
 status code and status
 text.
 Subclasses may want to override this method to to customize the processing.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.StatusLineprotected void writeRequest(HttpState state, HttpConnection conn) throws IOException, HttpException
 Sends the request via the given connection.
 
The request is written as the following sequence of actions:
writeRequestLine(HttpState, HttpConnection) is invoked to 
 write the request line.
 writeRequestHeaders(HttpState, HttpConnection) is invoked 
 to write the associated headers.
 writeRequestBody(HttpState, HttpConnection) is invoked to 
 write the body part of the request.
 Subclasses may want to override one or more of the above methods to to customize the processing. (Or they may choose to override this method if dramatically different processing is required.)
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected boolean writeRequestBody(HttpState state, HttpConnection conn) throws IOException, HttpException
connection.
 This method should return true if the request body was actually sent (or is empty), or false if it could not be sent for some reason.
This implementation writes nothing and returns true.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.protected void writeRequestHeaders(HttpState state, HttpConnection conn) throws IOException, HttpException
connection.
 
 This implementation invokes addRequestHeaders(HttpState,HttpConnection),
 and then writes each header to the request stream.
 
Subclasses may want to override this method to to customize the processing.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.addRequestHeaders(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpState, edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection), 
getRequestHeaders()protected void writeRequestLine(HttpState state, HttpConnection conn) throws IOException, HttpException
connection.
 Subclasses may want to override this method to to customize the processing.
state - the state information associated with this methodconn - the connection used to execute
        this HTTP methodIOException - if an I/O (transport) error occurs. Some transport exceptions
                     can be recovered from.HttpException - if a protocol exception occurs. Usually protocol exceptions 
                    cannot be recovered from.generateRequestLine(edu.internet2.middleware.grouperClientExt.org.apache.commons.httpclient.HttpConnection, java.lang.String, java.lang.String, java.lang.String, java.lang.String)public HttpMethodParams getParams()
HTTP protocol parameters associated with this method.getParams in interface HttpMethodHttpMethodParamspublic void setParams(HttpMethodParams params)
HTTP protocol parameters for this method.setParams in interface HttpMethodHttpMethodParamspublic HttpVersion getEffectiveVersion()
public String getProxyAuthenticationRealm()
public String getAuthenticationRealm()
protected String getContentCharSet(Header contentheader)
contentheader - The content header.public String getRequestCharSet()
public String getResponseCharSet()
public int getRecoverableExceptionCount()
protected void responseBodyConsumed()
The default behavior for this class is to check to see if the connection should be closed, and close if need be, and to ensure that the connection is returned to the connection manager - if and only if we are not still inside the execute call.
public HostConfiguration getHostConfiguration()
host configuration.getHostConfiguration in interface HttpMethodpublic void setHostConfiguration(HostConfiguration hostconfig)
host configuration.hostconfig - The hostConfiguration to setpublic MethodRetryHandler getMethodRetryHandler()
HttpMethodParamsretry handler for this HTTP methodpublic void setMethodRetryHandler(MethodRetryHandler handler)
HttpMethodParamsretry handler for this HTTP methodhandler - the methodRetryHandler to use when this method executedpublic AuthState getHostAuthState()
authentication stategetHostAuthState in interface HttpMethodpublic AuthState getProxyAuthState()
authentication stategetProxyAuthState in interface HttpMethodpublic boolean isAborted()
public boolean isRequestSent()
isRequestSent in interface HttpMethodCopyright © 2021 Internet2. All rights reserved.