大佬教程收集整理的这篇文章主要介绍了更改 KTor 客户端中的身份验证凭据,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
如何更改 KTor 客户端中的凭据?
创建客户端时@R_673_10936@Auth功能。我稍后尝试这样做,但它似乎不起作用,无论是第一次设置还是重复设置。
文档建议在客户端创建后保留它,因为设置很昂贵,因此无法更改凭据似乎过于严格(而且 jetBrains 的聪明人肯定不会这样做)。
>我有一个有效的答案,令我惊讶的是,但我不确定这是一个好的答案。欢迎评论。
因为文档说创建客户端很昂贵,所以我把它放在一个单例中,然后我做了这样的事情
@ThreadLocal
Object Serverlink {
fun setClIEnt(ID:string,pw:string) {
// Create the clIEnt here and set ID and pw
}
}
然后我只需在需要时调用 Serverlink.setClIEnt(newID,newPW) 即可。是的,这有效,我不认为我有多个线程,但这不会是内存泄漏,或者至少是内存浪费吗?
您可以通过获取对 Auth
功能的引用并更改其提供程序列表来实现。以下是在创建客户端后更改基本身份验证凭据的示例:
val client = httpClient(CIO) {
install(Auth) {
basic {
username = "user"
password = "password"
}
}
}
val auth = client.feature(Auth)
if (auth != null) {
auth.providers.removeAt(0)
auth.basic {
username = "new-user"
password = "new-password"
}
}
val r = client.get<String>("http://httpbin.org/basic-auth/new-user/new-password")
println(r)
以上是大佬教程为你收集整理的更改 KTor 客户端中的身份验证凭据全部内容,希望文章能够帮你解决更改 KTor 客户端中的身份验证凭据所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。