博客
关于我
Retrofit2.0 OkHttp如何自动加载Cookie 持久化
阅读量:747 次
发布时间:2019-03-22

本文共 2063 字,大约阅读时间需要 6 分钟。

今天给大家分享如何在Retrofit2.0和OkHttp中实现用户Cookie的持久化管理,从而实现免登录功能。

需求说明

我们的项目需要实现用户登录之后,下次访问系统时会自动携带之前保存的Cookie。这样用户就无需手动登录,每次请求都能通过已存储的Cookie进行验证。

解决思路

  • 使用OkHttp拦截器:在OkHttp请求过程中拦截,并获取服务器返回的Cookie。
  • 存储Cookie:将获取到的Cookie存储在本地,供后续使用。
  • 添加Cookie:在后续的每个请求中,将存储的Cookie添加到请求头,一起发送到服务器。
  • 具体实现步骤

  • 创建拦截器类

    • ReceivedCookiesInterceptor:用于获取服务器返回的Cookie。
      public class ReceivedCookiesInterceptor implements Interceptor {    @Override    public Response intercept(Chain chain) throws IOException {        Response originalResponse = chain.proceed(chain.request());        if (!originalResponse.headers("Set-Cookie").isEmpty()) {            for (String header : originalResponse.headers("Set-Cookie")) {                cookies.add(header);            }        }        return originalResponse;    }}
    • AddCookiesInterceptor:用于在请求头中添加存储的Cookie。
      public class AddCookiesInterceptor implements Interceptor {    @Override    public Response intercept(Chain chain) throws IOException {        Request.Builder builder = chain.request().newBuilder();        for (String cookie : cookies) {            builder.addHeader("Cookie", cookie);            Log.v("OkHttp", "Adding Header: " + cookie);        }        return chain.proceed(builder.build());    }}
  • 配置Retrofit和OkHttpClient

    • 创建OkHttpClient并添加拦截器
      OkHttpClient okHttpClient = new OkHttpClient.Builder()        .addInterceptor(new AddCookiesInterceptor())        .addInterceptor(new ReceivedCookiesInterceptor())        .connectTimeout(30, TimeUnit.SECONDS)        .build();
    • 创建Retrofit对象
      Retrofit retrofit = new Retrofit.Builder()        .baseUrl(Constant.BASE_URL)        .addConverterFactory(GsonConverterFactory.create())        .addCallAdapterFactory(RxJavaCallAdapterFactory.create())        .client(okHttpClient)        .build();
  • 使用Retrofit发起请求

    • 定义接口并创建调用实例:
      @GET("/token")void getToken(@Header("Content-Type") String type);retrofit.create();
  • 测试和验证

    • 通过工具如Fiddler抓包,确保Cookie被正确接收和添加。
    • 检查日志,确保AddCookiesInterceptor正确添加了Cookie。
  • 总结

    通过上述方法,成功实现了用户Cookie的持久化管理。每次请求前,Will AddCookiesInterceptor自动将存储的Cookie添加到请求头中,从而支持无需手动登录的功能。这种方式高效且易于集成,适用于需要短期用户记忆功能的场景。

    转载地址:http://yrawk.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>