本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
如何解决依赖冲突?
使用时 适用于 Kotlin 的 AWS SDK,它需要某些依赖项 AWS 和第三方依赖关系才能正常工作。如果缺少这些依赖项或在运行时出现意外版本,则可能会看到类似NoSuchMethodError
或的错误NoClassDefFoundError
。这些依赖问题通常分为两组:
-
SDK/Smithy 依赖冲突
-
第三方依赖冲突
当你构建 Kotlin 应用程序时,你很可能会使用 Gradle 来管理依赖关系。在项目中添加对 SDK 服务客户端的依赖关系会自动包含所有必要的相关依赖项。但是,如果您的应用程序有其他依赖项,则它们可能会与 SDK 所需的依赖项发生冲突。例如,SDK 依赖 OkHttp于您的应用程序也可能使用的流行的 HTTP 客户端。为了帮助您发现这些冲突,Gradle 提供了一个方便的任务,它列出了项目的依赖关系:
./gradlew dependencies
遇到依赖关系冲突时,可能需要采取措施。您可以将依赖关系的特定版本或影子依赖项指定到本地命名空间。Gradle 依赖关系解析是一个复杂的主题,将在 Gradle 用户手册的以下章节中讨论:
管理项目中的 SDK 和 Smithy 依赖关系
使用 SDK 时,请记住,其模块通常依赖于版本号匹配的其他 SDK 模块。例如,aws.sdk.kotlin:s3:1.2.3
依赖于 aws.sdk.kotlin:aws-http:1.2.3
,后者依赖于aws.sdk.kotlin:aws-core:1.2.3
,依此类推。
SDK 模块还使用特定的 Smithy 模块版本。虽然 Smithy 模块版本与 SDK 版本号不同步,但它们必须与 SDK 的预期版本相匹配。例如,aws.sdk.kotlin:s3:1.2.3
可能依赖于aws.smithy.kotlin:serde:1.1.1
,哪个取决于aws.smithy.kotlin:runtime-core:1.1.1
,依此类推。
为避免依赖冲突,请同时升级所有 SDK 依赖项,并对任何明确的 Smithy 依赖项执行相同的操作。考虑使用我们的 Gradle 版本目录来保持版本同步,并消除在 SDK 和 Smithy 版本之间映射时的猜测。
请记住, SDK/Smithy 模块中的次要版本更新可能包括重大更改,如我们的版本控制政策
解决应用程序中的 OkHttp 版本冲突
OkHttpokhttp3
命名空间中的类变为,例如okhttp/coroutines/ExecuteAsyncKt
或okhttp3/ConnectionListener
。NoClassDefFoundError
发生这种情况时,通常应选择较新的版本来解决冲突。为了帮助您追踪这些冲突的根源,Gradle 提供了一项有用的任务。你可以通过运行以下命令列出所有依赖关系:
./gradlew dependencies
例如,如果 SDK 依赖于其他依赖项 OkHttp 5.0.0-alpha.14
,例如 Spring Boot 依赖于其他依赖项, OkHttp 4.12.0
那么你应该使用5.0.0-alpha.14 version
。你可以在 Gradle 中使用constraints
方块来做到这一点:
dependencies { constraints { implementation("com.squareup.okhttp3:okhttp:4.12.0") } }
或者,如果您必须使用 OkHttp 4.x,SDK 会提供。OkHttp4Engine
有关如何配置 Gradle 并在代码OkHttp4Engine
中使用的信息,请参阅文档