【发布时间】:2015-04-16 16:11:10
【问题描述】:
我需要在OkHttp Interceptor 内重试请求。例如,有一个需要Authorization 令牌的传入请求。如果Authorization 令牌已过期,服务器将返回带有403 代码的响应。在这种情况下,我正在检索一个新令牌并尝试使用相同的 chain 对象再次拨打电话。
但是 OkHttp 会抛出一个异常,指出您不能使用相同的 chain 对象发出两个请求。
java.lang.IllegalStateException: network interceptor org.app.api.modules.ApplicationApiHeaders@559da2 must call proceed() exactly once
我想知道OkHttp Interceptor内部重试网络请求的问题是否有一个干净的解决方案?
public final class ApplicationApiHeaders implements Interceptor {
private static final String AUTHORIZATION = "Authorization";
private TokenProvider mProvider;
public ApplicationApiHeaders(TokenProvider provider) {
mProvider = provider;
}
@Override
public Response intercept(Chain chain) throws IOException {
Token token = mProvider.getApplicationToken();
String bearerToken = "Bearer " + token.getAccessToken();
System.out.println("Token: " + bearerToken);
Request request = chain.request();
request = request.newBuilder()
.addHeader(AUTHORIZATION, bearerToken)
.build();
Response response = chain.proceed(request);
if (!response.isSuccessful() && isForbidden(response.code())) {
Token freshToken = mProvider.invalidateAppTokenAndGetNew();
String freshBearerToken = freshToken.getAccessToken();
Request newRequest = chain.request();
newRequest = newRequest.newBuilder()
.addHeader(AUTHORIZATION, freshBearerToken)
.build();
response = chain.proceed(newRequest);
}
return response;
}
private static boolean isForbidden(int code) {
return code == HttpURLConnection.HTTP_FORBIDDEN;
}
}
【问题讨论】:
标签: java retrofit okhttp interceptor