public abstract class HttpExchange extends Object
 A HttpExchange must be closed to free or reuse
 underlying resources. The effect of failing to close an exchange
 is undefined.
| Modifier and Type | Field and Description | 
|---|---|
| static String | REQUEST_CIPHER_SUITEStandard property: cipher suite value when the request is received
 over HTTPS | 
| static String | REQUEST_KEY_SIZEStandard property: bit size of the algorithm when the request is
 received over HTTPS | 
| static String | REQUEST_X509CERTIFICATEStandard property: A SSL certificate, if any, associated with the request | 
| Constructor and Description | 
|---|
| HttpExchange() | 
| Modifier and Type | Method and Description | 
|---|---|
| abstract void | addResponseHeader(String name,
                 String value)Adds a response header with the given name and value. | 
| abstract void | close()This must be called to end an exchange. | 
| abstract Object | getAttribute(String name)Returns an attribute that is associated with this
  HttpExchange. | 
| abstract Set<String> | getAttributeNames()Gives all the attribute names that are associated with
 this  HttpExchange. | 
| abstract String | getContextPath()Returns the context path of all the endpoints in an application. | 
| abstract HttpContext | getHttpContext()Returns a  HttpContextfor this exchange. | 
| abstract InetSocketAddress | getLocalAddress()Returns the unresolved local address on which the request was received. | 
| abstract String | getPathInfo()Returns the extra path information that follows the web service
 path but precedes the query string in the request URI and will start
 with a "/" character. | 
| abstract String | getProtocol()Returns the protocol string from the request in the form
 protocol/majorVersion.minorVersion. | 
| abstract String | getQueryString()Returns the query string that is contained in the request URI
 after the path. | 
| abstract InetSocketAddress | getRemoteAddress()Returns the unresolved address of the remote entity invoking
 this request. | 
| abstract InputStream | getRequestBody()Returns a stream from which the request body can be read. | 
| abstract String | getRequestHeader(String name)Returns the value of the specified request header. | 
| abstract Map<String,List<String>> | getRequestHeaders()Returns an immutable Map containing the HTTP headers that were
 included with this request. | 
| abstract String | getRequestMethod()Get the HTTP request method | 
| abstract String | getRequestURI()Returns the part of the request's URI from the protocol
 name up to the query string in the first line of the HTTP request. | 
| abstract OutputStream | getResponseBody()Returns a stream to which the response body must be
 written. | 
| abstract Map<String,List<String>> | getResponseHeaders()Returns a mutable Map into which the HTTP response headers can be stored
 and which will be transmitted as part of this response. | 
| abstract String | getScheme()Returns the name of the scheme used to make this request,
 for example: http, or https. | 
| abstract Principal | getUserPrincipal()Returns the  Principalthat represents the authenticated
 user for thisHttpExchange. | 
| abstract boolean | isUserInRole(String role)Indicates whether an authenticated user is included in the specified
 logical "role". | 
| abstract void | setStatus(int status)Sets the HTTP status code for the response. | 
public static final String REQUEST_CIPHER_SUITE
Type: String
public static final String REQUEST_KEY_SIZE
Type: Integer
public static final String REQUEST_X509CERTIFICATE
Type: java.security.cert.X509Certificate[] The order of this array is defined as being in ascending order of trust. The first certificate in the chain is the one set by the client, the next is the one used to authenticate the first, and so on.
public abstract Map<String,List<String>> getRequestHeaders()
The keys in Map are case-insensitive.
public abstract String getRequestHeader(String name)
getRequestHeaders()).name - the name of the request headerpublic abstract Map<String,List<String>> getResponseHeaders()
The keys in Map are case-insensitive.
public abstract void addResponseHeader(String name, String value)
getResponseHeaders()).name - the name of the headervalue - the additional header value. If it contains octet string,
        it should be encoded according to
        RFC 2047 (http://www.ietf.org/rfc/rfc2047.txt)getResponseHeaders()public abstract String getRequestURI()
public abstract String getContextPath()
 Context path is used in computing the endpoint address. See
 HttpContext.getPath()
HttpContext.getPath()public abstract String getRequestMethod()
public abstract HttpContext getHttpContext()
HttpContext for this exchange.
 Container matches the request with the associated Endpoint's HttpContextpublic abstract void close()
                    throws IOException
IOException - if any i/o errorpublic abstract InputStream getRequestBody() throws IOException
IOException - if any i/o error during request processingpublic abstract OutputStream getResponseBody() throws IOException
setStatus(int)) must be called prior to calling
 this method. Multiple calls to this method (for the same exchange)
 will return the same stream.IOException - if any i/o error during response processingpublic abstract void setStatus(int status)
 This method must be called prior to calling getResponseBody().
status - the response code to sendgetResponseBody()public abstract InetSocketAddress getRemoteAddress()
public abstract InetSocketAddress getLocalAddress()
public abstract String getProtocol()
public abstract String getScheme()
public abstract String getPathInfo()
 This can be used for MessageContext.PATH_INFO
public abstract String getQueryString()
 This can be used for MessageContext.QUERY_STRING
public abstract Object getAttribute(String name)
HttpExchange. JAX-WS handlers and endpoints may then
 access the attribute via MessageContext.
 
 Servlet containers must expose MessageContext.SERVLET_CONTEXT,
 MessageContext.SERVLET_REQUEST, and
 MessageContext.SERVLET_RESPONSE
 as attributes.
 
If the request has been received by the container using HTTPS, the
 following information must be exposed as attributes. These attributes
 are REQUEST_CIPHER_SUITE, and REQUEST_KEY_SIZE.
 If there is a SSL certificate associated with the request, it must
 be exposed using REQUEST_X509CERTIFICATE
name - attribute namepublic abstract Set<String> getAttributeNames()
HttpExchange.getAttribute(String)public abstract Principal getUserPrincipal()
Principal that represents the authenticated
 user for this HttpExchange.public abstract boolean isUserInRole(String role)
role - specifies the name of the role Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2019, Oracle and/or its affiliates.  All rights reserved.