gpt4 book ai didi

android - 带有动态拦截器的 Okhttp3 Dagger2 中的最佳作用域

转载 作者:太空宇宙 更新时间:2023-11-03 13:49:26 25 4
gpt4 key购买 nike

作用域如何与 Auth Tokens 一起使用?在我可以添加一个使用我的身份验证 token 对其进行签名的拦截器之前,我无法创建我的 Retrofit 实例。因此,我想在身份验证 token 可用时(登录后)创建 Retrofit。在这种情况下如何让示波器正常工作?

非常感谢!

最佳答案

没有最好的方法可以做到这一点,它还可能取决于您更改/重新创建Retrofit 实例的频率。

哪个更好,或者哪个更适合您的用例,这在很大程度上取决于您要完成什么以及如何完成。有很多方法可以实现您想要实现的目标,但通常您有 2 个选择

  • 为每个改造实例创建一个新客户端(例如,如果您只让用户登录一次),那么您只需在同一范围内添加客户端
  • 创建 okhttp3 的 @Singleton 实例,并在需要时使用 newBuilder() 修改客户端

我认为第一点是不言自明的,只需在创建改造时创建客户端,使用相同的范围即可完成。


第二种方法使用 newBuilder() 方法的 Okhttp3 功能,在创建改造实例时将拦截器添加到 okhttp 客户端。

它看起来像这样:

// Some singleton client to maybe also use in other parts of your app
@Singleton
OkHttpClient provideClient() { return new OkHttpClient(); }

// creating your retrofit client
@UserScope
Retrofit provideRetrofit(OkHtpClient client, Interceptor userInterceptor) {
return new Retrofit.Builder()
.client(client.newBuilder() // new builder to modify okhttp3
.addNetworkInterceptor(interceptor)
.build())
/* other settings */
.build();
}

如果你有创意,你也可以在你的拦截器上公开一个 setCredentials() 方法,然后你可以只创建它们一次并通过将它们添加到 @Singleton 来重用所有对象 范围。然后您可以通过访问和修改您的拦截器来更改您的用户,尽管在我看来这不是一个干净的方法。

关于android - 带有动态拦截器的 Okhttp3 Dagger2 中的最佳作用域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37050348/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com