【发布时间】:2015-04-03 02:21:20
【问题描述】:
我正在使用带有 Okhttp 拦截器的 Retrofit 来检测我的 oauth 令牌是否已过期。如果令牌已过期,我想请求一个新令牌,再次尝试请求,然后将该响应发送给 Retrofit。
这是我的拦截器类:
public class CustomInterceptor implements Interceptor {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
// try the request
Response response = chain.proceed(request);
if (response.body().string().contains(Constants.TOKEN_AUTH_ERROR_MESSAGE)) {
Log.v("retrofit_error", "token expired");
//get current token, create headers
OAuthTokenResponse expiredToken = SharedPreferencesUtil.getOAuthToken();
OAuthTokenResponse newOauthToken = RestClient.getInstance().getTokenService().refreshOauthToken(expiredToken.getRefreshToken());
//store new token, return
SharedPreferencesUtil.saveOAuthToken(newOauthToken);
// create a new request and modify it accordingly using the new token
Request.Builder newRequestBuilder = request.newBuilder()
.removeHeader("Authorization");
Request newRequest = newRequestBuilder.addHeader("Authorization", SharedPreferencesUtil.getOAuthToken().getAccessToken()).build();
// retry the request
return chain.proceed(newRequest);
}
// otherwise just pass the original response on
return response;
}
}
问题是调用 response.body.string() 将消耗 ResponseBody,因为它是 Okhttp 文档状态的一次性值。
这意味着在代码末尾返回的 Response 在传递给改造时将不再包含正文。有什么方法可以消耗身体,同时仍将其与响应一起返回?
谢谢!
【问题讨论】:
-
您可以使用相同的正文创建新的响应,但我更建议您使用标头而不是正文来传输此类信息。
-
谢谢!你是对的。我没有看到 ResponseBody 构建器。尽管按照您的建议,我能够验证我可以使用标头中的 response.message。
-
或者,在此处查看此答案stackoverflow.com/questions/27922703/…
-
太棒了!我搜索了一段时间,看看是否有其他人有这个问题,但我找不到那个链接。谢谢!
标签: java android retrofit okhttp