热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

在运行时使用Dagger添加RetrofitRequestinterceptor

如何解决《在运行时使用Dagger添加RetrofitRequestinterceptor》经验,为你挑选了1个好方法。

我正在使用匕首和改装.我用Dagger注入了我的Retrofit服务.

现在我想做一个授权请求来获取accessToken.

之后我想使用Request拦截器来增强我的api模块,以便将来使用此访问令牌.

我的想法是在收到访问令牌后使用ObjectGraph.plus()方法,但我不确定这是否是最好的方法.

有人能指出我正确的方向,或者github上有一个示例项目吗?



1> Jake Wharton..:

关键是要始终添加RequestInterceptor然后更改它是否添加标题.

class ApiHeaders implements RequestInterceptor {
  private String authValue;

  public void clearAuthValue() {
    authValue = null;
  }

  public void setAuthValue(String authValue) {
    this.authValue = authValue;
  }

  @Override public void intercept(RequestFacade request) {
    String authValue = this.authValue;
    if (authValue != null) {
      request.addHeader("Authorization", authValue);
    }
  }
}

这样,您可以ApiHeaders在需要设置或清除令牌时注入单例.


推荐阅读
author-avatar
手机用户2602918765
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有