StrictMode 策略违规:android.os.strictmode.NonSdkApiUsedViolation: Lcom/android/org/conscrypt/ConscryptEn

Posted

技术标签:

【中文标题】StrictMode 策略违规:android.os.strictmode.NonSdkApiUsedViolation: Lcom/android/org/conscrypt/ConscryptEngineSocket;->setHostname(【英文标题】:StrictMode policy violation: android.os.strictmode.NonSdkApiUsedViolation: Lcom/android/org/conscrypt/ConscryptEngineSocket;->setHostname( 【发布时间】:2021-07-28 06:49:45 【问题描述】:

在应用发布之前,我在 Google Play 中出现以下错误。这不是警告,而是错误。我可以看到具有类似堆栈跟踪的警告。我不确定该应用程序是否会因此而被拒绝,因为发布前报告的摘要令人困惑。它说没有问题。但是在稳定性下它会显示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 Google Play 控制台已强调需要在移至 prod 之前修复该错误。有 2 个错误和 10 个警告。上面那一项被标记为错误 我明白了。我自己的应用程序有很多 StrictMode 政策违规行为,但没有一个阻止我发布。正如您所指出的,这可能是 OkHttp 中的一个问题。我不使用 React Native,但这听起来像是如果你还没有升级到最新版本可以解决的问题。 @ManishHaldankar 我对 RN 也有同样的问题。你能解决这个问题吗? 我在 Flutter 应用中遇到了同样的问题。有这方面的更新吗? 【参考方案1】:

我发现改成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 版本中使用吗?【参考方案2】:

使用gradlew app_name:dependencies 命令我发现了旧的firebase crashlytics 版本使用旧的com.squareup.okhttp3version。更改我的 gradle 配置以使用最新的 firebase crashlytics 解决了这个问题。

【讨论】:

以上是关于StrictMode 策略违规:android.os.strictmode.NonSdkApiUsedViolation: Lcom/android/org/conscrypt/ConscryptEn的主要内容,如果未能解决你的问题,请参考以下文章

转:StrictMode使用

Android性能优化—StrictMode的使用

App优化 StrictMode 严格模式

Android严苛模式StrictMode使用与取消

显示 Javascript“同源策略”违规

Android 分支 IO SDK 策略违规