android – 实现重试时的逻辑

android – 实现重试时的逻辑,第1张

概述我有一个应用程序,需要会话(cookie)来处理网络电话.我正在使用Retrofit Rx Java.但是,会话可能会过期(使用401 Unauthorized状态进行Retrofit错误)并且我想重新进行身份验证(以获取新的cookie)并在此情况下重试之前的呼叫.我如何用RxJava做到这一点? 我的例子: getServerApi().getDialogs(offset, getCookie 我有一个应用程序,需要会话(cookie)来处理网络电话.我正在使用Retrofit Rx Java.但是,会话可能会过期(使用401 Unauthorized状态进行Retrofit错误)并且我想重新进行身份验证(以获取新的cookie)并在此情况下重试之前的呼叫.我如何用RxJava做到这一点?

我的例子:

getServerAPI().getDialogs(offset,getcookies())     .subscribeOn(Schedulers.newThread())     .observeOn(AndroIDSchedulers.mainThread())     .retrywhen(observable -> {...}) // Need some logic     .subscribe(dialogsEnvelope -> getVIEw().setDialogs(dialogsEnvelope),throwable -> getVIEw().setError(processFail(throwable)));
解决方法 使用Okhttp非常强大的 Interceptor.
public class RecoverInterceptor implements Interceptor {  String getAuth() {    // check if we have auth,if not,authorize    return "Bearer ...";  }  voID clearauth() {    // clear everything  }  @OverrIDe public Response intercept(Chain chain) throws IOException {    final Request request = chain.request();    if (request.urlString().startsWith("MY ENDPOINT")) {      final Request signed = request.newBuilder()          .header("Authorization",getAuth())          .build();      final Response response = chain.proceed(signed);      if (response.code() == 401) {        clearauth();        return intercept(chain);      } else {        return response;      }    } else {      return chain.proceed(request);    }  }}

请记住同步您的身份验证进程代码,以便两个并发请求不会同时调用它.

总结

以上是内存溢出为你收集整理的android – 实现重试时的逻辑全部内容,希望文章能够帮你解决android – 实现重试时的逻辑所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1137325.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-30
下一篇2022-05-30

发表评论

登录后才能评论

评论列表(0条)

    保存