我用的是改装版2.0.0-beta2。
我发现了一个同步转换的example错误体到对象。
我需要异步实现它。
这是我的json:
{
"error_msg": "This user name is already registered."
}
当运行异步示例时,我得到空值。
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." :))))))
*/
}
}
对不起我的英语不好:)
在异步请求中成功返回字符串。但是,转换到对象的操作没有运行。
如何获取对象而不是空值?
最佳答案
好的,那么您的问题就在下面的代码行中: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();