在 ktor httpClient(js) JS 引擎中忽略自签名证书的配置

问题描述

Kotlin 多平台库,我的设置如下所示。 显然,我的 JS 测试失败并显示错误错误:无法获取”,因为 Ktor httpClient(JS) 未配置为忽略/信任自签名证书。并且根据 documentation “Js 引擎没有自定义配置。” 所以我的问题是有没有办法实现这一点,使我的测试通过 JS 平台。 或者你知道任何解决方法吗?还是我在这里遗漏了什么?

expect object Provider {
    fun createClient(): HttpClient
}

//JVM
actual object Provider {
    actual fun createClient(): HttpClient {
        return HttpClient(Apache) {
            install(JsonFeature) {
                serializer = KotlinxSerializer()
            }
            engine {
                customizeClient {
                    setSSLContext(
                        SSLContextBuilder
                            .create()
                            .loadTrustMaterial(TrustSelfSignedStrategy())
                            .build()
                    )
                    setSSLHostnameVerifier(NoopHostnameVerifier())
                }
            }
        }
    }
}

//JS
actual object Provider {
    actual fun createClient(): HttpClient {
        return HttpClient(Js) {
            install(JsonFeature) {
                serializer = KotlinxSerializer()
            }
        }
    }
}

解决方法

作为一种解决方法,在 Node.js 目标上,您可以设置环境变量 NODE_TLS_REJECT_UNAUTHORIZED 以禁用所有证书验证:

js("process.env.NODE_TLS_REJECT_UNAUTHORIZED = \"0\";")
val client = HttpClient(Js)
client.get<String>("https://localhost:8443/")