首页 > 其他分享 >OkHttp实现全局过期token自动刷新

OkHttp实现全局过期token自动刷新

时间:2023-04-26 15:25:23浏览次数:47  
标签:return 请求 过期 token loginInfo OkHttp new response

原文地址 www.cnblogs.com

遇到问题:


当前开发的 App 遇到一个问题:

当请求某个接口时,由于 token 已经失效,所以接口会报错。
但是产品经理希望 app 能够马上刷新 token ,然后重复请求刚才那个接口,这个过程对用户来说是无感的。

也就是静默自动登录,然后继续请求:

请求 A 接口-》服务器返回 token 过期-》请求 token 刷新接口-》请求 A 接口

要实现上述需求的话,大家会如何实现呢?

解决方案:


思路:
1.通过拦截器,获取返回的数据
2.判断token是否过期
3.如果token过期则刷新token
4.使用最新的token,重新请求网络数据

 1 /**
 2  * 全局自动刷新Token的拦截器
 3  */
 4 public class TokenInterceptor implements Interceptor {
 5 
 6     @Override
 7     public Response intercept(Chain chain) throws IOException {
 8         Request request = chain.request();
 9         Response response = chain.proceed(request);
10         LogUtil.print("response.code=" + response.code());
11 
12         if (isTokenExpired(response)) {//根据和服务端的约定判断token过期
13             LogUtil.print("静默自动刷新Token,然后重新请求数据");
14             //同步请求方式,获取最新的Token
15             String newSession = getNewToken();
16             //使用新的Token,创建新的请求
17             Request newRequest = chain.request()
18                     .newBuilder()
19                     .header("Cookie", "JSESSIONID=" + newSession)
20                     .build();
21             //重新请求
22             return chain.proceed(newRequest);
23         }
24         return response;
25     }
26 
27     /**
28      * 根据Response,判断Token是否失效
29      *
30      * @param response
31      * @return
32      */
33     private boolean isTokenExpired(Response response) {
34         if (response.code() == 404) {
35             return true;
36         }
37         return false;
38     }
39 
40     /**
41      * 同步请求方式,获取最新的Token
42      *
43      * @return
44      */
45     private String getNewToken() throws IOException {
46         // 通过一个特定的接口获取新的token,此处要用到同步的retrofit请求
47         Response_Login loginInfo = CacheManager.restoreLoginInfo(BaseApplication.getContext());
48         String username = loginInfo.getUserName();
49         String password = loginInfo.getPassword();
50 
51         LogUtil.print("loginInfo=" + loginInfo.toString());
52         Call<Response_Login> call = WebHelper.getSyncInterface().synclogin(new Request_Login(username, password));
53         loginInfo = call.execute().body();
54         LogUtil.print("loginInfo=" + loginInfo.toString());
55 
56         loginInfo.setPassword(password);
57         CacheManager.saveLoginInfo(loginInfo);
58         return loginInfo.getSession();
59     }
60 }

然后配置下OkHttp

HttpLoggingInterceptor logging = new HttpLoggingInterceptor();
        logging.setLevel(HttpLoggingInterceptor.Level.BODY);

        OkHttpClient client = new OkHttpClient.Builder()
                .connectTimeout(15, TimeUnit.SECONDS)
                .readTimeout(300, TimeUnit.SECONDS)
                .writeTimeout(300, TimeUnit.SECONDS)
                .cache(new Cache(FileConstants.HTTP_CACHE_DIR, FileConstants.CACHE_SIZE))
                .addInterceptor(interceptor)
//                .addInterceptor(new MockInterceptor())
                .addInterceptor(new TokenInterceptor())
//                .addInterceptor(new RetryIntercepter(3))
                .addInterceptor(logging)
                .build();

标签:return,请求,过期,token,loginInfo,OkHttp,new,response
From: https://www.cnblogs.com/cps666/p/17356177.html

相关文章

  • shell脚本找出不过期的redis key
    1#!/bin/bash2#Redis通过scan找出不过期的key3#SCAN命令是一个基于游标的迭代器(cursorbasediterator):SCAN命令每次被调用之后,都会向用户返回一个新的游标,用户在下次迭代时需要使用这个新游标作为SCAN命令的游标参数,以此来延续之前的迭代过程。4#注意:当S......
  • P.19-token认证过滤器代码实现、P.20-配置认证过滤器、P.21-退出登录
    P.19-token认证过滤器代码实现自定义一个过滤器,这个过滤器会去获取请求头中的token,对token进行解析取出其中的userid。使用userid去redis中获取对应的LoginUser对象。然后封装Authentication对象存入SecurityContextHolder@ComponentpublicclassJwtAuthentica......
  • JWT 实现登录认证 + Token 自动续期方案 转载
    过去这段时间主要负责了项目中的用户管理模块,用户管理模块会涉及到加密及认证流程,加密已经在前面的文章中介绍了。今天就来讲讲认证功能的技术选型及实现。技术上没啥难度当然也没啥挑战,但是对一个原先没写过认证功能的菜鸡甜来说也是一种锻炼吧。技术选型要实现认证功能,很容易......
  • okhttp3的基本使用(post发送json示例)
    依赖<!--https://mvnrepository.com/artifact/com.squareup.okhttp3/okhttp--><dependency><groupId>com.squareup.okhttp3</groupId><artifactId>okhttp</artifactId><ve......
  • 批量删除docker过期停止的容器(全)
     过期的容器也是占用一部分的内存空间dockerps-a查看很多冗余过期的容器 这时候如果对应一个个删除容器id,有些麻烦,有没有方法对应将其批量删除呢答案:有的,本身命令行都是基于bash命令,可通过查询其容器,筛选其容器id,并将这部分容器进行删除即可关于docker的详细知识点可看我......
  • C# 使用jwt生成token
    publicstaticstringSetJwtEncode(CarGateLoginInputDtopayload,stringsign){IJwtAlgorithmalgorithm=newHMACSHA256Algorithm();IJsonSerializerserializer=newJsonNetSerializer();IBase64UrlEncoderurlEncoder=newJwtBase64Url......
  • SpringBoot 使用 Sa-Token 完成权限认证
    一、设计思路所谓权限认证,核心逻辑就是判断一个账号是否拥有指定权限:有,就让你通过。没有?那么禁止访问!深入到底层数据中,就是每个账号都会拥有一个权限码集合,框架来校验这个集合中是否包含指定的权限码。例如:当前账号拥有权限码集合["user-add","user-delete","user-get"]......
  • token认证过滤器代码实现与配置认证过滤器
    token认证过滤器代码实现认证过滤器​我们需要自定义一个过滤器,这个过滤器会去获取请求头中的token,对token进行解析取出其中的userid。​使用userid去redis中获取对应的LoginUser对象。​然后封装Authentication对象存入SecurityContextHolder......
  • powershell过滤当月过期用户
    echo"默认开始日期为【1】号|默认结束日期为【下月1】号"#获取过滤数据的月份$Start_Time =Read-Host"请输入开始月份"$End_Time =Read-Host"请输入结束月份"#假如用户需要的五月份的数据,结束月份加1,结束日期默认为1号$monthNum=[int]$End_Time#如果月份小于12,则......
  • 大语言模型中的token解释
    在大型语言模型中,"token"通常指的是一个离散的文本单元,它可以是单词、标点符号、数字或其他语言元素,这些元素被用作训练和生成文本的基本单位。在NLP中,通常使用tokenization技术将文本分割成token序列。具体来说,tokenization是将一个连续的文本字符串分割成一个个离散的单词......