Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Asynchronous Http and WebSocket Client library for Java

License

NotificationsYou must be signed in to change notification settings

pubsrc/async-http-client

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Follow@AsyncHttpClient on Twitter.

The AsyncHttpClient (AHC) library allows Java applications to easily execute HTTP requests and asynchronously process HTTP responses.The library also supports the WebSocket Protocol.

It's built on top ofNetty. It's currently compiled on Java 8 but runs on Java 9 too.

Installation

Binaries are deployed on Maven central:

<dependency><groupId>org.asynchttpclient</groupId><artifactId>async-http-client</artifactId><version>LATEST_VERSION</version></dependency>

Version

AHC doesn't use SEMVER, and won't.

  • MAJOR = huge refactoring
  • MINOR = new features and minor API changes, upgrading should require 1 hour of work to adapt sources
  • FIX = no API change, just bug fixes, only those are source and binary compatible with same minor version

Check CHANGES.md for migration path between versions.

Basics

Feel free to check theJavadoc or the code for more information.

Dsl

Import the Dsl helpers to use convenient methods to bootstrap components:

importstaticorg.asynchttpclient.Dsl.*;

Client

importstaticorg.asynchttpclient.Dsl.*;AsyncHttpClientasyncHttpClient =asyncHttpClient();

AsyncHttpClient instances must be closed (call theclose method) once you're done with them, typically when shutting down your application.If you don't, you'll experience threads hanging and resource leaks.

AsyncHttpClient instances are intended to be global resources that share the same lifecycle as the application.Typically, AHC will usually underperform if you create a new client for each request, as it will create new threads and connection pools for each.It's possible to create shared resources (EventLoop and Timer) beforehand and pass them to multiple client instances in the config. You'll then be responsible for closing those shared resources.

Configuration

Finally, you can also configure the AsyncHttpClient instance via its AsyncHttpClientConfig object:

importstaticorg.asynchttpclient.Dsl.*;AsyncHttpClientc =asyncHttpClient(config().setProxyServer(proxyServer("127.0.0.1",38080)));

HTTP

Sending Requests

Basics

AHC provides 2 APIs for defining requests: bound and unbound.AsyncHttpClient and Dls` provide methods for standard HTTP methods (POST, PUT, etc) but you can also pass a custom one.

importorg.asynchttpclient.*;// boundFuture<Response>whenResponse =asyncHttpClient.prepareGet("http://www.example.com/").execute();// unboundRequestrequest =get("http://www.example.com/").build();Future<Response>whenResponse =asyncHttpClient.execute(request);

Setting Request Body

Use thesetBody method to add a body to the request.

This body can be of type:

  • java.io.File
  • byte[]
  • List<byte[]>
  • String
  • java.nio.ByteBuffer
  • java.io.InputStream
  • Publisher<io.netty.bufferByteBuf>
  • org.asynchttpclient.request.body.generator.BodyGenerator

BodyGenerator is a generic abstraction that let you create request bodies on the fly.Have a look atFeedableBodyGenerator if you're looking for a way to pass requests chunks on the fly.

Multipart

Use theaddBodyPart method to add a multipart part to the request.

This part can be of type:

  • ByteArrayPart
  • FilePart
  • InputStreamPart
  • StringPart

Dealing with Responses

Blocking on the Future

execute methods return ajava.util.concurrent.Future. You can simply block the calling thread to get the response.

Future<Response>whenResponse =asyncHttpClient.prepareGet("http://www.example.com/").execute();Responseresponse =whenResponse.get();

This is useful for debugging but you'll most likely hurt performance or create bugs when running such code on production.The point of using a non blocking client is toNOT BLOCK the calling thread!

Setting callbacks on the ListenableFuture

execute methods actually return aorg.asynchttpclient.ListenableFuture similar to Guava's.You can configure listeners to be notified of the Future's completion.

ListenableFuture<Response>whenResponse = ???;Runnablecallback = () -> {try  {Responseresponse =whenResponse.get();System.out.println(response);}catch (InterruptedException |ExecutionExceptione) {e.printStackTrace();}};java.util.concurrent.Executorexecutor = ???;whenResponse.addListener(() -> ???,executor);

If theexecutor parameter is null, callback will be executed in the IO thread.YouMUST NEVER PERFORM BLOCKING operations in there, typically sending another request and block on a future.

Using custom AsyncHandlers

execute methods can take anorg.asynchttpclient.AsyncHandler to be notified on the different events, such as receiving the status, the headers and body chunks.When you don't specify one, AHC will use aorg.asynchttpclient.AsyncCompletionHandler;

AsyncHandler methods can let you abort processing early (returnAsyncHandler.State.ABORT) and can let you return a computation result fromonCompleted that will be used as the Future's result.SeeAsyncCompletionHandler implementation as an example.

The below sample just capture the response status and skips processing the response body chunks.

Note that returningABORT closes the underlying connection.

importstaticorg.asynchttpclient.Dsl.*;importorg.asynchttpclient.*;importio.netty.handler.codec.http.HttpHeaders;Future<Integer>whenStatusCode =asyncHttpClient.prepareGet("http://www.example.com/").execute(newAsyncHandler<Integer>() {privateIntegerstatus;@OverridepublicStateonStatusReceived(HttpResponseStatusresponseStatus)throwsException {status =responseStatus.getStatusCode();returnState.ABORT;}@OverridepublicStateonHeadersReceived(HttpHeadersheaders)throwsException {returnState.ABORT;}@OverridepublicStateonBodyPartReceived(HttpResponseBodyPartbodyPart)throwsException {returnState.ABORT;}@OverridepublicIntegeronCompleted()throwsException {returnstatus;}@OverridepublicvoidonThrowable(Throwablet) {}});IntegerstatusCode =whenStatusCode.get();

Using Continuations

ListenableFuture has atoCompletableFuture method that returns aCompletableFuture.Beware that canceling thisCompletableFuture won't properly cancel the ongoing request.There's a very good chance we'll return aCompletionStage instead in the next release.

CompletableFuture<Response>whenResponse =asyncHttpClient            .prepareGet("http://www.example.com/")            .execute()            .toCompletableFuture()            .exceptionally(t -> {/* Something wrong happened... */  } )            .thenApply(response -> {/*  Do something with the Response */returnresp; });whenResponse.join();// wait for completion

You may get the complete maven project for this simple demo fromorg.asynchttpclient.example

WebSocket

Async Http Client also supports WebSocket.You need to pass aWebSocketUpgradeHandler where you would register aWebSocketListener.

WebSocketwebsocket =c.prepareGet("ws://demos.kaazing.com/echo")      .execute(newWebSocketUpgradeHandler.Builder().addWebSocketListener(newWebSocketListener() {@OverridepublicvoidonOpen(WebSocketwebsocket) {websocket.sendTextFrame("...").sendTextFrame("...");          }@OverridepublicvoidonClose(WebSocketwebsocket) {          }@OverridepublicvoidonTextFrame(Stringpayload,booleanfinalFragment,intrsv) {System.out.println(payload);          }@OverridepublicvoidonError(Throwablet) {          }      }).build()).get();

Reactive Streams

AsyncHttpClient has built-in support for reactive streams.

You can pass a request body as aPublisher<ByteBuf> or aReactiveStreamsBodyGenerator.

You can also pass aStreamedAsyncHandler<T> whoseonStream method will be notified with aPublisher<HttpResponseBodyPart>.

See tests in packageorg.asynchttpclient.reactivestreams for examples.

WebDAV

AsyncHttpClient has build in support for the WebDAV protocol.The API can be used the same way normal HTTP request are made:

RequestmkcolRequest =newRequestBuilder("MKCOL").setUrl("http://host:port/folder1").build();Responseresponse =c.executeRequest(mkcolRequest).get();

or

RequestpropFindRequest =newRequestBuilder("PROPFIND").setUrl("http://host:port").build();Responseresponse =c.executeRequest(propFindRequest,newAsyncHandler() {// ...}).get();

More

You can find more information on Jean-François Arcand's blog. Jean-François is the original author of this library.Code is sometimes not up-to-date but gives a pretty good idea of advanced features.

User Group

Keep up to date on the library development by joining the Asynchronous HTTP Client discussion group

Google Group

Contributing

Of course, Pull Requests are welcome.

Here are the few rules we'd like you to respect if you do so:

  • Only edit the code related to the suggested change, so DON'T automatically format the classes you've edited.
  • Use IntelliJ default formatting rules.
  • Regarding licensing:
    • You must be the original author of the code you suggest.
    • You must give the copyright to "the AsyncHttpClient Project"

About

Asynchronous Http and WebSocket Client library for Java

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java99.9%
  • Other0.1%

[8]ページ先頭

©2009-2025 Movatter.jp