Retrofit 2.0 Convertor返回NULL

时间:2015-10-07 16:00:29

标签: android json asynchronous callback retrofit

我使用 Retrofit 2.0.0-beta2

我发现<{>>同步转换 .errorBody example为对象。

我需要异步实现它。

这是我的json:

{
  "error_msg": "This user name is already registered."
}

运行异步示例时,我会 null

package com.test.client;

import com.squareup.okhttp.ResponseBody;

import java.io.IOException;
import java.lang.annotation.Annotation;

import retrofit.Call;
import retrofit.Callback;
import retrofit.Converter;
import retrofit.GsonConverterFactory;
import retrofit.Response;
import retrofit.Retrofit;
import retrofit.http.GET;

public final class DeserializeErrorBody {

interface Service {
    @GET("account.signup")
    Call<User> getUser();
}

static class User {
    // normal fields...
}

static class Error {
    String error_msg;
}

public static void main(String... args) throws IOException {
    Retrofit retrofit = new Retrofit.Builder()
            .baseUrl("https://api.site.com/method/")
            .addConverterFactory(GsonConverterFactory.create())
            .build();

    Service service = retrofit.create(Service.class);


    // ASYNCHRONOUS

    Call<User> response = service.getUser();
    response.enqueue(new Callback<User>() {

        @Override
        public void onResponse(Response<User> response, Retrofit retrofit) {
            if(!responce.isSuccess()) {

                System.out.println(response.errorBody().string()); // returns { "error_msg": "This user name is already registered."}    :)))))

                Converter<ResponseBody, Error> errorConverter = retrofit.responseConverter(Error.class, new Annotation[0]);

                try {
                    Error error = errorConverter.convert(response.errorBody());

                    System.out.println(error); // returns null   :((((((

                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }

        @Override
        public void onFailure(Throwable t) {
            // ...
        }
    });


    // SYNCHRONOUS

    /*
    Response<User> call = service.getUser().execute();
    Converter<ResponseBody, Error> errorConverter = retrofit.responseConverter(Error.class, new Annotation[0]);

    Error error = errorConverter.convert(call.errorBody());
    System.out.println(error); // returns Object     :))))))
    System.out.println(error.error_msg); // returns "This user name is already registered."    :))))))
    */

}
}

抱歉我的英语不好:)

在异步请求中成功返回字符串。但是,转换为对象 正在运行。

如何获取对象而不是 null

1 个答案:

答案 0 :(得分:4)

好的,所以你的问题在于以下代码行:

System.out.println(response.errorBody().string());

如果您查看com.squareapp.okhttp.ResponseBody的来源,您会发现对string()的调用将消耗响应流。所以下次你试图解析响应体

Error error = errorConverter.convert(response.errorBody());

调用errorBody()不会产生任何字节流,Gson也不会解析任何数据。

那你该怎么办?只是不要像你那样消费errorBody()。只需删除此行:

System.out.println(response.errorBody().string());

如果您需要高级记录follow link。这基本上应该是这样的:

OkHttpClient client = new OkHttpClient();
HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
logging.setLevel(Level.BASIC);
client.interceptors().add(logging);

Retrofit retrofit = new Retrofit.Builder()
       .baseUrl("https://api.site.com/method/")
       .addConverterFactory(GsonConverterFactory.create())
       .client(client)
       .build();