All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jetty.client.package-info Maven / Gradle / Ivy

There is a newer version: 3.9
Show newest version
//
//  ========================================================================
//  Copyright (c) 1995-2013 Mort Bay Consulting Pty. Ltd.
//  ------------------------------------------------------------------------
//  All rights reserved. This program and the accompanying materials
//  are made available under the terms of the Eclipse Public License v1.0
//  and Apache License v2.0 which accompanies this distribution.
//
//      The Eclipse Public License is available at
//      http://www.eclipse.org/legal/epl-v10.html
//
//      The Apache License v2.0 is available at
//      http://www.opensource.org/licenses/apache2.0.php
//
//  You may elect to redistribute this code under either of these licenses.
//  ========================================================================
//

/**
 * This package provides APIs, utility classes and an implementation of an asynchronous HTTP client.
 * 

* The core class is {@link HttpClient}, which acts as a central configuration object (for example * for {@link HttpClient#setIdleTimeout(long) idle timeouts}, {@link HttpClient#setMaxConnectionsPerDestination(int) * max connections per destination}, etc.) and as a factory for {@link Request} objects. *

* The HTTP protocol is based on the request/response paradigm, a unit that in this implementation is called * exchange and is represented by {@link HttpExchange}. * An initial request may trigger a sequence of exchanges with one or more servers, called a conversation * and represented by {@link HttpConversation}. A typical example of a conversation is a redirect, where * upon a request for a resource URI, the server replies with a redirect (for example with the 303 status code) * to another URI. This conversation is made of a first exchange made of the original request and its 303 response, * and of a second exchange made of the request for the new URI and its 200 response. *

* {@link HttpClient} holds a number of {@link HttpDestination destinations}, which in turn hold a number of * pooled {@link HttpConnection connections}. *

* When a request is sent, its exchange is associated to a connection, either taken from an idle queue or created * anew, and when both the request and response are completed, the exchange is disassociated from the connection. * Conversations may span multiple connections on different destinations, and therefore are maintained at the * {@link HttpClient} level. *

* Applications may decide to send the request and wait for the response in a blocking way, using * {@link Request#send()}. * Alternatively, application may ask to be notified of response events asynchronously, using * {@link Request#send(Response.Listener)}. */ package org.eclipse.jetty.client;





© 2015 - 2025 Weber Informatics LLC | Privacy Policy