我使用 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 ?
答案 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();