3

ステータス >=400 が返された場合の HTTP レスポンス コンテンツの取得方法。それは私のコードサンプルです:

    try {
        ChatService client = ProxyFactory.create(ChatService.class, apiUrl);
        client.putMessage(dto);
    } catch (ClientResponseFailure ex) {
        System.out.println(ex.getResponse().getEntity().toString());
    }

これはスローします:

Exception in thread "main" org.jboss.resteasy.spi.ReaderException: java.io.IOException: Stream closed
    at org.jboss.resteasy.core.messagebody.ReaderUtility.doRead(ReaderUtility.java:123)
    at org.jboss.resteasy.client.core.BaseClientResponse.readFrom(BaseClientResponse.java:246)
    at org.jboss.resteasy.client.core.BaseClientResponse.getEntity(BaseClientResponse.java:210)
    at org.jboss.resteasy.client.core.BaseClientResponse.getEntity(BaseClientResponse.java:171)
    at App.main(App.java:40)
Caused by: java.io.IOException: Stream closed
    at java.io.BufferedInputStream.getInIfOpen(BufferedInputStream.java:134)
    at java.io.BufferedInputStream.fill(BufferedInputStream.java:218)
    at java.io.BufferedInputStream.read1(BufferedInputStream.java:258)
    at java.io.BufferedInputStream.read(BufferedInputStream.java:317)
    at org.jboss.resteasy.client.core.SelfExpandingBufferredInputStream.read(SelfExpandingBufferredInputStream.java:58)
    at java.io.FilterInputStream.read(FilterInputStream.java:90)
    at org.jboss.resteasy.client.core.SelfExpandingBufferredInputStream.read(SelfExpandingBufferredInputStream.java:68)
    at org.jboss.resteasy.util.ReadFromStream.readFromStream(ReadFromStream.java:30)
    at org.jboss.resteasy.plugins.providers.ByteArrayProvider.readFrom(ByteArrayProvider.java:32)
    at org.jboss.resteasy.plugins.providers.ByteArrayProvider.readFrom(ByteArrayProvider.java:23)
    at org.jboss.resteasy.core.interception.MessageBodyReaderContextImpl.proceed(MessageBodyReaderContextImpl.java:105)
    at org.jboss.resteasy.plugins.interceptors.encoding.GZIPDecodingInterceptor.read(GZIPDecodingInterceptor.java:46)
    at org.jboss.resteasy.core.interception.MessageBodyReaderContextImpl.proceed(MessageBodyReaderContextImpl.java:108)
    at org.jboss.resteasy.core.messagebody.ReaderUtility.doRead(ReaderUtility.java:111)
    ... 4 more

ステータス コード 400 以外の詳細を知りたいです。

4

2 に答える 2

0

デバッグ中に、必要な詳細が XML のバイト ストリームとして「streamFactory」オブジェクトにあることに気付きました。ClientResponseに関する RestEasy ドキュメントでこのヘルプ トピックを見つけました。それは言う

getEntity(java.lang.Class<T2> type) 

getEntity は、出力を目的のクラスにマーシャリングできます。私の場合、ServiceError というサービスから返されるエラー用のカスタム クラスがあります。これが getEntity に渡したクラスです。

try {
    serviceResult = proxy.addCustomer(customerName, customerProfile);
} catch (ClientResponseFailure ex) {
    ClientResponse<String> cResp = ex.getResponse();
    ServiceError myEntity = cResp.getEntity(ServiceError.class);
    System.out.println("myEntity errorText=" + myEntity.getErrorMessage().getErrorText());
    System.out.println("myEntity errorCode=" + myEntity.getErrorMessage().getErrorCode());
}
于 2012-02-10T18:09:50.507 に答える
0

それはあなたが送信するつもりだった例外ですか?

残念ながら、RestEASY クライアント フレームワークは例外のマーシャリング自体をサポートしておらず、代わりに HTTP フレームワークに適応させています。ただし、サーバーでは例外がスローされるはずです。チェック済みの例外には ExceptionMappers を使用できます。

http://docs.jboss.org/resteasy/docs/1.2.GA/userguide/html/ExceptionHandling.html

于 2010-06-23T17:09:01.367 に答える