严格模式违规:android.os.strictmode.NonSdkApiUsedViolation:Lcom/android/org/conscrypt/ConscryptEngineSocket;->setHostname()

12

在应用发布到 Google Play 前,我遇到了以下错误。这不是一个警告,而是一个错误。我可以看到类似堆栈跟踪的警告。我不确定应用是否会因此被拒绝,因为 Pre-launch 报告的摘要很令人困惑。它显示没有问题。但在稳定性下,它显示了 Android 兼容性下的警告和错误。这似乎是由 React Native 使用的一些库(从一些类似帖子中看来,似乎是 okhttp)引起的,但我不确定这个跟踪意味着什么。

我非常新于 React Native,不确定如何解决此问题。我找不到任何解决方案,只有一些类似的帖子但没有解决方案。我们的应用因此问题而无法发布。任何帮助都将不胜感激。

StrictMode policy violation: android.os.strictmode.NonSdkApiUsedViolation: Lcom/android/org/conscrypt/ConscryptEngineSocket;->setHostname(Ljava/lang/String;)V
    at android.os.StrictMode.lambda$static$1(StrictMode.java:416)
    at android.os.-$$Lambda$StrictMode$lu9ekkHJ2HMz0jd3F8K8MnhenxQ.accept(Unknown Source:2)
    at java.lang.Class.getDeclaredMethodInternal(Native Method)
    at java.lang.Class.getPublicMethodRecursive(Class.java:2079)
    at java.lang.Class.getMethod(Class.java:2066)
    at java.lang.Class.getMethod(Class.java:1693)
    at okhttp3.internal.platform.OptionalMethod.getPublicMethod(OptionalMethod.java:164)
    at okhttp3.internal.platform.OptionalMethod.getMethod(OptionalMethod.java:149)
    at okhttp3.internal.platform.OptionalMethod.invokeOptional(OptionalMethod.java:66)
    at okhttp3.internal.platform.OptionalMethod.invokeOptionalWithoutCheckedException(OptionalMethod.java:86)
    at okhttp3.internal.platform.AndroidPlatform.configureTlsExtensions(AndroidPlatform.java:123)
    at okhttp3.internal.connection.RealConnection.connectTls(RealConnection.java:314)
    at okhttp3.internal.connection.RealConnection.establishProtocol(RealConnection.java:283)
    at okhttp3.internal.connection.RealConnection.connect(RealConnection.java:168)
    at okhttp3.internal.connection.StreamAllocation.findConnection(StreamAllocation.java:257)
    at okhttp3.internal.connection.StreamAllocation.findHealthyConnection(StreamAllocation.java:135)
    at okhttp3.internal.connection.StreamAllocation.newStream(StreamAllocation.java:114)
    at okhttp3.internal.connection.ConnectInterceptor.intercept(ConnectInterceptor.java:42)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)
    at okhttp3.internal.cache.CacheInterceptor.intercept(CacheInterceptor.java:93)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)
    at okhttp3.internal.http.BridgeInterceptor.intercept(BridgeInterceptor.java:93)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
    at okhttp3.internal.http.RetryAndFollowUpInterceptor.intercept(RetryAndFollowUpInterceptor.java:126)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
    at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)
    at okhttp3.RealCall.getResponseWithInterceptorChain(RealCall.java:254)
    at okhttp3.RealCall$AsyncCall.execute(RealCall.java:200)
    at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
    at java.lang.Thread.run(Thread.java:923)

虽然您会想要尝试解决这个问题,但我不认为这会阻止您的应用程序被发布。 - Bink
1
感谢@Bink。Google Play控制台已经强调,在进入生产环境之前需要修复错误。总共有2个错误和10个警告。上面的一个被标记为错误。 - Manish Haldankar
我明白了。我的应用程序有很多StrictMode策略违规,但从未阻止我发布。也许这是像你所指出的OkHttp的问题。我不使用React Native,但如果您还没有升级到最新版本,这听起来可能是可以解决的问题。 - Bink
@ManishHaldankar 我用RN也遇到了同样的问题。你解决了吗? - Newoda
我在Flutter应用程序中遇到了相同的问题。这方面有任何更新吗? - Denis Gordin
@ManishHaldankar,你的应用因为这个被拒绝了吗?我也遇到了类似的问题,但是在应用中没有发现任何问题。所以我在检查预发布报告时偶然发现了这里。应用因为他们遇到的崩溃而被拒绝了,但是无法在所有可用设备上重现。 - sanister
2个回答

5
我发现将okhttp3升级至3.12.13版本可以解决这个错误。 https://square.github.io/okhttp/changelog_3x/ 在android/app/build.gradle文件中添加以下两行代码。
implementation("com.squareup.okhttp3:okhttp:3.12.13")
implementation("com.squareup.okhttp3:okhttp-urlconnection:3.12.13")

然而,仍然存在一些警告,但至少没有错误。


这个能在React Native版本中使用吗? - philk

2
通过运行gradlew app_name:dependencies命令,我发现旧的firebase crashlytics版本使用了旧的com.squareup.okhttp3版本。将我的gradle配置更改为使用最新的firebase crashlytics解决了问题。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接