1. 什么是UTDID冲突?
Android UTDID包命名形式为:
utdid4all-x.x.x.jar
,iOS UTDID包命名格式为:UTDID.framework
。UTDID
作为阿里集团移动端SDK通用组件,包括阿里云在内的许多平台产品移动端SDK对其有依赖,若同时集成多平台移动端SDK,可能发生UTDID冲突
。
2. 怎么解决UTDID冲突?
【注意】Android UTDID版本号必须
>= v1.1.5.3
,若不能确认UTDID版本号,请参考下述方案,保留阿里云平台的UTDID包。
2.1 手动集成解决方案
- 手动删除重复的UTDID SDK,仅保留一个UTDID SDK。
- 建议保留阿里云平台下载的UTDID SDK。
2.2 远程仓库集成解决方案
- Android集成时,可以通过
exclude
关闭其他产品SDK对UTDID的传递性依赖,示例如下所示:
compile ('com.xxx:xxx.xxx:1.0.1') {
exclude (module: 'utdid4all')
}
其module名不一定为
utdid4all
,具体如何关闭UTDID的传递性依赖,可咨询对应产品SDK接口人。iOS集成时,如果通过CocoaPods进行远程仓库依赖,由于CocoaPods无法关闭传递性依赖,SDK集成需要修改为
手动集成
。
2.3 与支付宝SDK UTDID冲突
- 支付宝SDK是通过源码方式集成的UTDID,所以不适用于上述的
手动集成解决方案
和远程仓库集成解决方案
。 - 可下载并集成 剥离UTDID的支付宝SDK,保留阿里云平台的UTDID包。
- 该版本SDK和通用支付宝SDK保持同步更新,无需担心支付宝相关功能受影响。
文档内容是否对您有帮助?