我正在使用带有 Okhttp 拦截器的 Retrofit 来检测我的 oauth token 是否已过期。如果 token 已过期,我想请求一个新 token ,再次尝试请求,然后将该响应发送给 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 将不再包含主体,当它被传递到改造时。有什么方法可以在消耗主体的同时仍将其与响应一起返回吗?
谢谢!
最佳答案
我通过使用 Response.Builder 创建一个新响应来完成此操作.我可以使用 responseBodyString
进行检查;然后我返回 newResponse
,这是我消费的主体。
Request request = chain.request();
Response response = chain.proceed(request);
ResponseBody responseBody = response.body();
String responseBodyString = response.body().string();
Response newResponse = response.newBuilder().body(ResponseBody.create(responseBody.contentType(), responseBodyString.getBytes())).build();
...
return newResponse;
关于java - 从 Okhttp 使用 One-Shot ResponseBody 会导致 Retrofit 出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28306524/