Android 处理token过期

Android 处理token过期

在Android开发中,处理token过期通常涉及到网络请求的拦截和重新认证。以下是一个简单的示例,展示了如何在发起网络请求时检查token是否过期,并在过期时进行重新认证。

public class ApiHelper {
 
    private final OkHttpClient client;
    private Retrofit retrofit;
    private final String TOKEN_EXPIRED_CODE = "401";
 
    public ApiHelper() {
        client = new OkHttpClient();
        retrofit = new Retrofit.Builder()
                .baseUrl("https://your-api-url.com/")
                .addConverterFactory(GsonConverterFactory.create())
                .client(client)
                .build();
    }
 
    public <T> T createService(Class<T> serviceClass) {
        return retrofit.create(serviceClass);
    }
 
    public void checkTokenExpiration(final Call<ResponseBody> call, final TokenRefreshListener listener) {
        call.enqueue(new Callback<ResponseBody>() {
            @Override
            public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
                if (response.code() == 401) {
                    // Token has expired, refresh the token
                    listener.onTokenExpired();
                } else {
                    // Proceed with the response
                    listener.onSuccess(response);
                }
            }
 
            @Override
            public void onFailure(Call<ResponseBody> call, Throwable t) {
                // Handle the failure
                listener.onFailure(t);
            }
        });
    }
 
    public interface TokenRefreshListener {
        void onTokenExpired();
        void onSuccess(Response<ResponseBody> response);
        void onFailure(Throwable t);
    }
}

使用上述ApiHelper类,你可以在发起网络请求时调用checkTokenExpiration方法,并在回调中处理token过期和成功的情况。如果token过期,TokenRefreshListeneronTokenExpired方法会被调用,在这里你可以实现你的token刷新逻辑。

ApiHelper apiHelper = new ApiHelper();
Call<ResponseBody> yourApiCall = yourApiService.yourApiMethod();
apiHelper.checkTokenExpiration(yourApiCall, new ApiHelper.TokenRefreshListener() {
    @Override
    public void onTokenExpired() {
        // 刷新token的逻辑
        refreshToken();
    }
 
    @Override
    public void onSuccess(Response<ResponseBody> response) {
        // 处理响应
        handleResponse(response);
    }
 
    @Override
    public void onFailure(Throwable t) {
        // 处理错误
        handleError(t);
    }
});

refreshToken方法中,你可以向认证服务器发送一个请求来获取新的token,并在获取新token后重新发起原始的网络请求。这样就可以在token过期时自动处理认证和重试请求,而不需要用户手动干预。

  • 9
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@²⁰²⁴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值