- 含まれているインタフェース:
HttpResponse<T>
BodySubscriber
の実装。
次に、事前定義済の本文サブスクライバを使用して、レスポンス本文データのフローを一般的な高水準のJavaオブジェクトに変換する例を示します。
// Streams the response body to a File
HttpResponse<Path> response = client
.send(request, responseInfo -> BodySubscribers.ofFile(Paths.get("example.html"));
// Accumulates the response body and returns it as a byte[]
HttpResponse<byte[]> response = client
.send(request, responseInfo -> BodySubscribers.ofByteArray());
// Discards the response body
HttpResponse<Void> response = client
.send(request, responseInfo -> BodySubscribers.discarding());
// Accumulates the response body as a String then maps it to its bytes
HttpResponse<byte[]> response = client
.send(request, responseInfo ->
BodySubscribers.mapping(BodySubscribers.ofString(UTF_8), String::getBytes));
- 導入されたバージョン:
- 11
-
メソッドのサマリー
修飾子と型メソッド説明static <T> HttpResponse.BodySubscriber
<T> buffering
(HttpResponse.BodySubscriber<T> downstream, int bufferSize) 特定のダウンストリーム・サブスクライバにデータを配信する前にデータをバッファリングするBodySubscriber
を返します。static HttpResponse.BodySubscriber
<Void> レスポンス本文を破棄するレスポンス・サブスクライバを返します。static HttpResponse.BodySubscriber
<Void> fromLineSubscriber
(Flow.Subscriber<? super String> subscriber) 指定されたFlow.Subscriber
の行ごとにすべてのレスポンス本文を転送する本体サブスクライバを返します。static <S extends Flow.Subscriber<? super String>,
T>
HttpResponse.BodySubscriber<T> fromLineSubscriber
(S subscriber, Function<? super S, ? extends T> finisher, Charset charset, String lineSeparator) 指定されたFlow.Subscriber
の行ごとにすべてのレスポンス本文を転送する本体サブスクライバを返します。static HttpResponse.BodySubscriber
<Void> fromSubscriber
(Flow.Subscriber<? super List<ByteBuffer>> subscriber) すべてのレスポンス本文を指定されたFlow.Subscriber
に転送する本文サブスクライバを返します。static <S extends Flow.Subscriber<? super List<ByteBuffer>>,
T>
HttpResponse.BodySubscriber<T> fromSubscriber
(S subscriber, Function<? super S, ? extends T> finisher) すべてのレスポンス本文を指定されたFlow.Subscriber
に転送する本文サブスクライバを返します。static <T,
U> HttpResponse.BodySubscriber <U> mapping
(HttpResponse.BodySubscriber<T> upstream, Function<? super T, ? extends U> mapper) 指定されたupstream
BodySubscriber
の本体オブジェクトに指定された関数を適用した結果がレスポンス本文の値であるBodySubscriber
を返します。static HttpResponse.BodySubscriber
<byte[]> レスポンス本文をバイト配列として格納するBodySubscriber
を返します。static HttpResponse.BodySubscriber
<Void> ofByteArrayConsumer
(Consumer<Optional<byte[]>> consumer) 提供されたOptional<byte[]>
のコンシューマに着信する本文データを提供するBodySubscriber
を返します。static HttpResponse.BodySubscriber
<Path> 指定された名前でオープンされたファイルにレスポンス本文を格納するBodySubscriber
を返します。static HttpResponse.BodySubscriber
<Path> ofFile
(Path file, OpenOption... openOptions) 与えられたオプションと名前でオープンされたファイルにレスポンス本文を格納するBodySubscriber
を返します。レスポンス本文をInputStream
としてストリームするBodySubscriber
を返します。static HttpResponse.BodySubscriber
<Stream<String>> レスポンス本文をStream
<String>
としてストリームするBodySubscriber
を返します。このStream
<String>
は、ストリーム内の各文字列が、BufferedReader.lines()
で定義された行に対応します。Publisher<List<ByteBuffer>>
を介してレスポンス本文をパブリッシュするレスポンス・サブスクライバを返します。static HttpResponse.BodySubscriber
<String> 指定されたCharset
を使用して変換されたString
としてレスポンス本文を格納する本文サブスクライバを返します。static <U> HttpResponse.BodySubscriber
<U> replacing
(U value) レスポンス本文を破棄するレスポンス・サブスクライバを返します。
-
メソッドの詳細
-
fromSubscriber
public static HttpResponse.BodySubscriber<Void> fromSubscriber(Flow.Subscriber<? super List<ByteBuffer>> subscriber) すべてのレスポンス本文を指定されたFlow.Subscriber
に転送する本文サブスクライバを返します。 返された本文サブスクライバの「完了ステージ」は、指定されたサブスクライバonComplete
またはonError
のいずれかが呼び出されると完了します。- APIのノート:
- このメソッドは、
BodySubscriber
とFlow.Subscriber
の間のアダプタとして使用できます。 - パラメータ:
subscriber
- サブスクライバ- 戻り値:
- 本文サブスクライバ
-
fromSubscriber
public static <S extends Flow.Subscriber<? super List<ByteBuffer>>,T> HttpResponse.BodySubscriber<T> fromSubscriber(S subscriber, Function<? super S, ? extends T> finisher) すべてのレスポンス本文を指定されたFlow.Subscriber
に転送する本文サブスクライバを返します。 返された本文サブスクライバの「完了ステージ」は、指定されたサブスクライバonComplete
またはonError
のいずれかが呼び出されると完了します。指定された
finisher
関数は、指定されたサブスクライバのonComplete
が呼び出された後に適用されます。finisher
ファンクションは、指定されたサブスクライバとともに起動され、レスポンスの本文として設定された値を返します。- APIのノート:
- このメソッドは、
BodySubscriber
とFlow.Subscriber
の間のアダプタとして使用できます。 - 型パラメータ:
S
- サブスクライバのタイプT
- レスポンス本文のタイプ- パラメータ:
subscriber
- サブスクライバfinisher
- サブスクライバが完了した後に適用される機能- 戻り値:
- 本文サブスクライバ
-
fromLineSubscriber
public static HttpResponse.BodySubscriber<Void> fromLineSubscriber(Flow.Subscriber<? super String> subscriber) 指定されたFlow.Subscriber
の行ごとにすべてのレスポンス本文を転送する本体サブスクライバを返します。 返された本文サブスクライバの「完了ステージ」は、指定されたサブスクライバonComplete
またはonError
のいずれかが呼び出されると完了します。UTF-8
文字セットを使用してバイトがデコードされ、行がBufferedReader.readLine()
と同じように区切られます。- APIのノート:
- このメソッドは、
BodySubscriber
とFlow.Subscriber
の間のアダプタとして使用できます。 - 実装上のノート:
- これは、呼出しに相当します。
fromLineSubscriber(subscriber, s -> null, StandardCharsets.UTF_8, null)
- パラメータ:
subscriber
- サブスクライバ- 戻り値:
- 本文サブスクライバ
-
fromLineSubscriber
public static <S extends Flow.Subscriber<? super String>,T> HttpResponse.BodySubscriber<T> fromLineSubscriber(S subscriber, Function<? super S, ? extends T> finisher, Charset charset, String lineSeparator) 指定されたFlow.Subscriber
の行ごとにすべてのレスポンス本文を転送する本体サブスクライバを返します。 返された本文サブスクライバの「完了ステージ」は、指定されたサブスクライバonComplete
またはonError
のいずれかが呼び出されると完了します。指定された
finisher
関数は、指定されたサブスクライバのonComplete
が呼び出された後に適用されます。finisher
ファンクションは、指定されたサブスクライバとともに起動され、レスポンスの本文として設定された値を返します。- APIのノート:
- このメソッドは、
BodySubscriber
とFlow.Subscriber
の間のアダプタとして使用できます。 - 型パラメータ:
S
- サブスクライバのタイプT
- レスポンス本文のタイプ- パラメータ:
subscriber
- サブスクライバfinisher
- サブスクライバが完了した後に適用される機能charset
- バイトをデコードするCharset
lineSeparator
- 行セパレータ(オプション):BufferedReader.readLine()
のように線が区切られるnull
にすることができます。- 戻り値:
- 本文サブスクライバ
- 例外:
IllegalArgumentException
- 指定されたlineSeparator
が空の文字列であるかどうか
-
ofString
public static HttpResponse.BodySubscriber<String> ofString(Charset charset) 指定されたCharset
を使用して変換されたString
としてレスポンス本文を格納する本文サブスクライバを返します。このサブスクライバを使用する
HttpResponse
は、レスポンス全体を読み取った後に使用できます。- パラメータ:
charset
- 文字列を変換する文字セット- 戻り値:
- 本文サブスクライバ
-
ofByteArray
public static HttpResponse.BodySubscriber<byte[]> ofByteArray()レスポンス本文をバイト配列として格納するBodySubscriber
を返します。このサブスクライバを使用する
HttpResponse
は、レスポンス全体を読み取った後に使用できます。- 戻り値:
- 本文サブスクライバ
-
ofFile
public static HttpResponse.BodySubscriber<Path> ofFile(Path file, OpenOption... openOptions) 与えられたオプションと名前でオープンされたファイルにレスポンス本文を格納するBodySubscriber
を返します。 ファイルは、本文が読み取られる直前にFileChannel.open
を使用して、指定されたオプションで開きます。 スローされた例外は、必要に応じてHttpClient::send
またはHttpClient::sendAsync
から返されるかスローされます。このサブスクライバを使用する
HttpResponse
は、レスポンス全体を読み取った後に使用できます。デフォルトのファイル・システム・プロバイダの場合、セキュリティ・マネージャのパーミッション・チェックは、
BodySubscriber
の作成時にこのファクトリ・メソッドで実行されます。 そうしないと、ファイル・アクセス時にコール元コンテキストに対して「権限チェック」が非同期に実行される可能性があります。BodySubscriber
が信頼できないコードと共有されないことに注意してください。- パラメータ:
file
- 本文を格納するファイルopenOptions
- ファイルを開くためのオプションのリスト- 戻り値:
- 本文サブスクライバ
- 例外:
IllegalArgumentException
- 無効なオープン・オプション・セットが指定されている場合SecurityException
- デフォルトのファイル・システム・プロバイダで、セキュリティ・マネージャがインストールされている場合は、指定されたファイルへの書込みアクセスをチェックするためにcheckWrite
が起動されます。
-
ofFile
public static HttpResponse.BodySubscriber<Path> ofFile(Path file) 指定された名前でオープンされたファイルにレスポンス本文を格納するBodySubscriber
を返します。同等:
ofFile(file, CREATE, WRITE)
デフォルトのファイル・システム・プロバイダの場合、セキュリティ・マネージャのパーミッション・チェックは、
BodySubscriber
の作成時にこのファクトリ・メソッドで実行されます。 そうしないと、ファイル・アクセス時にコール元コンテキストに対して「権限チェック」が非同期に実行される可能性があります。BodySubscriber
が信頼できないコードと共有されないことに注意してください。- パラメータ:
file
- 本文を格納するファイル- 戻り値:
- 本文サブスクライバ
- 例外:
SecurityException
- デフォルトのファイル・システム・プロバイダで、セキュリティ・マネージャがインストールされている場合は、指定されたファイルへの書込みアクセスをチェックするためにcheckWrite
が起動されます。
-
ofByteArrayConsumer
public static HttpResponse.BodySubscriber<Void> ofByteArrayConsumer(Consumer<Optional<byte[]>> consumer) 提供されたOptional<byte[]>
のコンシューマに着信する本文データを提供するBodySubscriber
を返します。Optional
が空の場合、Consumer.accept()
の各呼び出しには、空のOptional
が含まれます。ただし、すべての本文データが読み込まれた後の最終呼び出しを除きます。このサブスクライバを使用する
HttpResponse
は、レスポンス全体を読み取った後に使用できます。- APIのノート:
- このサブスクライバはフロー制御されません。 したがって、指定されたコンシューマは、タイムリに配信されるデータ量を処理できる必要があります。
- パラメータ:
consumer
- バイト配列のコンシューマ- 戻り値:
- a BodySubscriber
-
ofInputStream
public static HttpResponse.BodySubscriber<InputStream> ofInputStream()レスポンス本文をInputStream
としてストリームするBodySubscriber
を返します。このサブスクライバを使用する
HttpResponse
は、レスポンス・ヘッダーが読み込まれた直後に利用でき、本文全体が処理されるまで待つ必要はありません。 レスポンス本文は、InputStream
から直接読み取ることができます。- APIのノート:
- 対応するエクスチェンジに関連付けられたすべてのリソースが適切に解放されるようにするには、呼び出し側はEOFに達するまですべてのバイトを読み取るか、
InputStream.close()
を呼び出すことができない場合は呼び出します。 ストリームを使い切る前にclose
を呼び出すと、基になるHTTP接続が閉じられ、後続の操作で再利用されなくなる可能性があります。 - 実装上のノート:
- このメソッドのデフォルト実装によって返される
InputStream
のread
メソッドは、読取りのブロック中にスレッドが中断された場合、「スレッド割り込みステータスが設定されました」とともにIOException
をスローします。 その場合、リクエストも取り消され、InputStream
がクローズされます。 - 戻り値:
- レスポンス本文を
InputStream
としてストリームするボディ・サブスクライバ。
-
ofLines
public static HttpResponse.BodySubscriber<Stream<String>> ofLines(Charset charset) レスポンス本文をStream
<String>
としてストリームするBodySubscriber
を返します。このStream
<String>
は、ストリーム内の各文字列が、BufferedReader.lines()
で定義された行に対応します。このサブスクライバを使用する
HttpResponse
は、レスポンス・ヘッダーが読み込まれた直後に利用でき、本文全体が処理されるまで待つ必要はありません。 レスポンス本文は、Stream
から直接読み取ることができます。- APIのノート:
- 対応する交換に関連付けられているすべてのリソースが正常に解放されるようにするには、コール元が、ストリームが使い果たされるまですべての行を読み取るか、またはそれを使用不可にするか、
BaseStream.close()
を呼び出します。 ストリームを使い切る前にclose
を呼び出すと、基になるHTTP接続が閉じられ、後続の操作で再利用されなくなる可能性があります。 - パラメータ:
charset
- バイトを文字に変換する場合に使用する文字セット- 戻り値:
- レスポンス本文を
Stream
<String>
としてストリームする本文サブスクライバ。 - 関連項目:
-
ofPublisher
public static HttpResponse.BodySubscriber<Flow.Publisher<List<ByteBuffer>>> ofPublisher()Publisher<List<ByteBuffer>>
を介してレスポンス本文をパブリッシュするレスポンス・サブスクライバを返します。このサブスクライバを使用する
HttpResponse
は、レスポンス・ヘッダーが読み込まれた直後に利用でき、本文全体が処理されるまで待つ必要はありません。 その後、HttpResponse
body
メソッドによって返されたパブリッシャにサブスクライブすることによって、レスポンス本文のバイトを取得できます。body
メソッドによって返されたパブリッシャは、一度のみサブスクライブできます。 最初のサブスクライバは、正常にサブスクライブされた場合は本文レスポンス・バイトを受信し、それ以外の場合はサブスクリプションが取り消されます。 さらに多くのサブスクリプションが試行されると、後続のサブスクライバは空のサブスクリプションでただちにサブスクライブされ、onError
メソッドはIllegalStateException
で呼び出されます。- APIのノート:
- 対応する交換に関連付けられたすべてのリソースが適切に解放されるようにするには、呼出し側が、指定されたパブリッシャが一度サブスクライブされ、
onComplete
またはonError
が起動されるまですべてのバイトがサブスクライブされるようにするか、提供されたsubscriptionが起動できない場合はその操作を取り消す必要があります。 交換に使用される実際のHTTPプロトコルversionに応じて、フローを流用するかわりにサブスクリプションを取り消すと、基礎となるHTTP接続がクローズされ、後続の操作で再利用されるのを防ぐことができます。 - 戻り値:
Publisher<List<ByteBuffer>>
を介してレスポンス本文をに公開するBodySubscriber
。
-
replacing
public static <U> HttpResponse.BodySubscriber<U> replacing(U value) レスポンス本文を破棄するレスポンス・サブスクライバを返します。 指定された値は、HttpResponse.body()
から返される値です。- 型パラメータ:
U
- レスポンス本文のタイプ- パラメータ:
value
- HttpResponse.body()から返す値は、null
です- 戻り値:
- a
BodySubscriber
-
discarding
public static HttpResponse.BodySubscriber<Void> discarding()レスポンス本文を破棄するレスポンス・サブスクライバを返します。- 戻り値:
- レスポンス本文サブスクライバ
-
buffering
public static <T> HttpResponse.BodySubscriber<T> buffering(HttpResponse.BodySubscriber<T> downstream, int bufferSize) 特定のダウンストリーム・サブスクライバにデータを配信する前にデータをバッファリングするBodySubscriber
を返します。 サブスクライバは、onComplete
が呼び出される直前に、最後の呼び出しを除いて、bufferSize
バイトのデータをダウンストリームonNext
メソッドの各呼び出しに渡すことを保証します。onNext
の最後の呼び出しには、bufferSize
バイトより少ないバイト数が含まれている可能性があります。返されたサブスクライバは、
getBody()
メソッドをダウンストリーム・サブスクライバに委譲します。- 型パラメータ:
T
- レスポンス本文のタイプ- パラメータ:
downstream
- ダウンストリーム・サブスクライバbufferSize
- バッファ・サイズ- 戻り値:
- バファリング本体サブスクライバ
- 例外:
IllegalArgumentException
-bufferSize <= 0
の場合
-
mapping
public static <T,U> HttpResponse.BodySubscriber<U> mapping(HttpResponse.BodySubscriber<T> upstream, Function<? super T, ? extends U> mapper) 指定されたupstream
BodySubscriber
の本体オブジェクトに指定された関数を適用した結果がレスポンス本文の値であるBodySubscriber
を返します。マッピング関数は、クライアントexecutorを使用して実行されるため、
InputStream
のブロックなどのレスポンス本文のタイプをマップするために使用できます。 ただし、マッパー関数でブロック操作を実行すると、(少なくともブロッキング操作が終了するまで)の実行時間が不明な時間帯にはエグゼキュータ・スレッドをブロックするリスクがあり、使用可能なスレッドの実行時間が長くなる可能性があります。 したがって、目的の型へのマッピングが(例:InputStream
を読み込む場合)をブロックする場合、次の例に示すように、目的の型のSupplier
にマッピングして、コール元のスレッドによってSupplier::get
が起動されるまでブロック操作を遅延します。この場合、次の例では、一般的なJSONパーサーを使用して、InputStream
を注釈付きのいずれかのJava型に変換します。たとえば、
public static <W> BodySubscriber<Supplier<W>> asJSON(Class<W> targetType) { BodySubscriber<InputStream> upstream = BodySubscribers.ofInputStream(); BodySubscriber<Supplier<W>> downstream = BodySubscribers.mapping( upstream, (InputStream is) -> () -> { try (InputStream stream = is) { ObjectMapper objectMapper = new ObjectMapper(); return objectMapper.readValue(stream, targetType); } catch (IOException e) { throw new UncheckedIOException(e); } }); return downstream; }
- 型パラメータ:
T
- アップストリーム本文タイプU
- 戻された本文サブスクライバの型- パラメータ:
upstream
- マップされる本文サブスクライバmapper
- マッピング関数- 戻り値:
- マッピング本文サブスクライバ
-