我的第一个赌注是一个okhttpclIEnt拦截器,它将令牌添加到每个请求.但我不知道如何在拦截器内获得有效的令牌.
Googleapiclient的文档建议在每次获取有效令牌的请求之前调用silentSignIn(Googleapiclient).问题是我无法访问拦截器内当前连接的Googleapiclient.
解决方法 我最近遇到了类似的问题,我找到了一个不太漂亮但工作的解决方案.您可以使用静态变量.
public class SessionData { private static String sessionID; public static String getSessionID() { return sessionID; } public static voID setSessionID(String sessionID) { SessionData.sessionID = sessionID; } }
然后,您可以在从Google SDK获取IDToken之后设置IDToken(例如,在用户登录后).
SessionData.setSessionID(yourCurrentToken);
在您声明Retrofit.Builder的类中,您应该使用以下导入(如您所说,okhttp拦截器).
import com.squareup.okhttp.Interceptor;import com.squareup.okhttp.OkhttpClIEnt;import com.squareup.okhttp.Request;import com.squareup.okhttp.Response;
该类的内容应如下所示.
public class RestClIEnt implements Interceptor { public RestClIEnt() { OkhttpClIEnt httpClIEnt = new OkhttpClIEnt(); // add your other interceptors … // add logging as last interceptor httpClIEnt.interceptors().add(this); // <-- this adds the header with the sessionID to every request Retrofit restAdapter = new Retrofit.Builder() .baseUrl(RestConstants.BASE_URL) .addCallAdapterFactory(RxJavaCallAdapterFactory.create()) .addConverterFactory(GsonConverterFactory.create()) .clIEnt(httpClIEnt) .build(); } @OverrIDe public Response intercept(Chain chain) throws IOException { Request originalRequest = chain.request(); if (SessionData.getSessionID() != null) { Request newRequest = originalRequest.newBuilder() .header("sessionID",SessionData.getSessionID()) .build(); return chain.proceed(newRequest); } return chain.proceed(originalRequest); }}总结
以上是内存溢出为你收集整理的android – Retrofit2(拦截器)GoogleApiClient如何刷新令牌全部内容,希望文章能够帮你解决android – Retrofit2(拦截器)GoogleApiClient如何刷新令牌所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)