gpt4 book ai didi

java - 什么可能导致 Retrofit 忽略方法调用?

转载 作者:太空宇宙 更新时间:2023-11-04 13:53:42 25 4
gpt4 key购买 nike

我遇到了奇怪的行为。我的应用程序有一个主要 Activity ,其中包括抽屉导航布局和默认列表 fragment 。列表 fragment 使用Retrofit客户端来获取内容。选择列表项时会显示详细信息 View 。在小屏幕上,详细 View 是通过单独的 Activity 加载的。该 Activity 还使用 Retrofit 客户端来获取详细信息。然后,可以从 navdrawer 中选择一个选项来生成一个新的 Activity 。该 Activity 也使用 Retrofit 客户端发送数据。

列表和详细信息 Activity 可以很好地调用 Retrofit 方法。我可以看到日志并且一切都按预期运行。但是,通过导航选项打开的第三个 Activity 尝试调用被 Retrofit 忽略的 Retrofit 客户端方法。

在所有实例中,Retrofit 客户端都以相同的方式实例化:

protected ServerApi buildApi(String serverEndpoint) {
Gson gson = new GsonBuilder()
.create();

RestAdapter restAdapter = new RestAdapter.Builder()
.setLog(new AndroidLog("ServerApi"))
.setLogLevel(RestAdapter.LogLevel.FULL)
.setEndpoint(serverEndpoint)
.setErrorHandler(new ApiErrorHandler())
.setConverter(new GsonConverter(gson))
.build();

return restAdapter.create(ServerApi.class);
}

在列表和详细 Activity 中,我可以看到详细的 Retrofit 日志条目。但是,当我在第三个 Activity 中调用类似构造的 Retrofit 客户端时,没有日志输出,没有抛出错误,logcat 不打印任何内容。它几乎就像调用被忽略一样。

我确信服务器端点已正确设置,并且我还确保调用已执行。起初,我认为这可能是由于客户端的创建发生在 onCreate 中并在单独的线程上执行。但是,在创建客户端后立即进行测试调用不会产生任何结果。

有谁知道是什么可能导致仅在一项 Activity 中而不是其他 Activity 中出现这种奇怪的行为?

更新1

是的,我尝试到处记录。我更绝望的 Retrofit 客户端构建如下所示:

protected class ApiErrorHandler implements ErrorHandler {
@Override
public Throwable handleError(RetrofitError cause) {
Log.e(TAG, "Got API error " + cause);

Response r = cause.getResponse();
Throwable throwable = null;

if (r == null) {
return cause;
}

// Try to interpret the response
String responseBody = new String(((TypedByteArray) r.getBody()).getBytes());
Gson gson = new GsonBuilder().create();
BaseResponse response = null;

try {
response = gson.fromJson(responseBody, BaseResponse.class);
}
catch (Exception e) {
Log.e(TAG, "Could not parse the error response:" + e.getMessage());
}

return new ServerApiException(response.getErrorMessage());
}
}

protected class ApiRequestInterceptor implements RequestInterceptor {
@Override
public void intercept(RequestFacade request) {
Log.d(TAG, "Intercepted API request: " + request.toString());
}
}

RestAdapter restAdapter = new RestAdapter.Builder()
.setLog(new AndroidLog("ServerApi"))
.setLogLevel(RestAdapter.LogLevel.FULL)
.setEndpoint(mServerUrl)
.setErrorHandler(new ApiErrorHandler())
.setConverter(new GsonConverter(gson))
.setRequestInterceptor(new ApiRequestInterceptor())
.setProfiler(new Profiler() {
@Override
public Object beforeCall() {
Log.d("RetrofitProfiler", "Before call to retrofit");
return null;
}

@Override
public void afterCall(Profiler.RequestInformation requestInfo, long elapsedTime, int statusCode, Object beforeCallData) {
Log.d("RetrofitProfiler", String.format("HTTP %d %s %s (%dms)",
statusCode, requestInfo.getMethod(), requestInfo.getRelativePath(), elapsedTime));
}
})
.build();

更新2

好吧,我错了,但我不知道 Retrofit 至少依赖于一名订阅者的存在。我想这是有道理的,现在我想起来了……但它不是一劳永逸的。

我做错了什么:

mClient = new ServerClient(mServerEndpoint, mAccountToken);
mUvClient.getFeed(mFeedId);

这是我不知道的部分。您需要订阅可观察对象才能执行:

mClient = new ServerClient(mServerEndpoint, mAccountToken);
mUvClient.getFeed(mFeedId)
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Subscriber<FeedInfo>() {
@Override
public void onNext(FeedInfo feedInfo) {
Log.d(TAG, "on Next");
}

@Override
public void onCompleted() {
Log.d(TAG, "on completed");
}

@Override
public void onError(Throwable e) {
Log.d(TAG, "on error");
}
});

这会产生预期的 Retrofit 详细日志和结果。无论如何,我希望这对某人有帮助。

最佳答案

问题是我没有订阅由 Retrofit API 生成的 Observable。我以为它无论如何都会触发,但它没有,并且需要订阅。希望这对可能遇到此问题的其他人有所帮助。

关于java - 什么可能导致 Retrofit 忽略方法调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30043339/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com