Retrofit Token过期 重新请求Token再去请求接口 代码实现
时间: 2024-03-05 18:50:50 浏览: 190
Retrofit2::mushroom: Rxjava2+Retrofit2二次封装。动态代理实现token过期自动刷新,以及https相关配置,https单双向认证等
好的,以下是一个可能的代码实现,供您参考:
首先,我们需要定义一个TokenInterceptor拦截器类,用于在每次请求接口时检查Token是否过期:
```java
public class TokenInterceptor implements Interceptor {
private static final String TOKEN_KEY = "token";
private static final String AUTHORIZATION_HEADER = "Authorization";
private SharedPreferences mSharedPreferences;
public TokenInterceptor(Context context) {
mSharedPreferences = context.getSharedPreferences("my_prefs", Context.MODE_PRIVATE);
}
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
String token = mSharedPreferences.getString(TOKEN_KEY, "");
if (!TextUtils.isEmpty(token)) {
request = request.newBuilder()
.addHeader(AUTHORIZATION_HEADER, "Bearer " + token)
.build();
}
Response response = chain.proceed(request);
if (response.code() == 401) {
// Token过期,重新请求Token并重试请求
String newToken = getNewToken();
if (!TextUtils.isEmpty(newToken)) {
// 更新Token并重试请求
mSharedPreferences.edit().putString(TOKEN_KEY, newToken).apply();
Request newRequest = request.newBuilder()
.addHeader(AUTHORIZATION_HEADER, "Bearer " + newToken)
.build();
response = chain.proceed(newRequest);
}
}
return response;
}
private String getNewToken() {
// 发送获取新Token的请求,返回新Token
// 这里只是一个示例,具体实现可以根据实际情况来定
return null;
}
}
```
然后,在创建Retrofit实例时,添加上述拦截器:
```java
OkHttpClient client = new OkHttpClient.Builder()
.addInterceptor(new TokenInterceptor(context))
.build();
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(BASE_URL)
.client(client)
.addConverterFactory(GsonConverterFactory.create())
.build();
```
最后,在请求接口时,如果遇到Token过期的情况,TokenInterceptor会自动发送请求获取新Token,并重新发送接口请求:
```java
Call<MyResponse> call = apiService.getMyData();
call.enqueue(new Callback<MyResponse>() {
@Override
public void onResponse(Call<MyResponse> call, Response<MyResponse> response) {
if (response.isSuccessful()) {
// 请求成功
MyResponse myResponse = response.body();
// 处理返回的数据
} else {
// 请求失败
// 这里不需要处理401 Unauthorized错误,TokenInterceptor已经处理过了
}
}
@Override
public void onFailure(Call<MyResponse> call, Throwable t) {
// 请求失败
}
});
```
以上就是一个简单的Retrofit Token过期后重新请求Token再去请求接口的代码实现,仅供参考。
阅读全文