对于特定设备上的分析或欺诈预防等用例,您可能需要关联您的组织拥有的应用集中的使用情况或操作。Google Play 服务 提供了一种名为应用集 ID 的隐私友好型选项。
应用集 ID 范围
应用集 ID 可以具有以下定义的范围之一。要确定特定 ID 与哪个范围相关联,请调用 getScope()
。
Google Play 开发者范围
对于通过 Google Play 商店安装的应用,应用集 ID API 会返回一个范围限定为在同一 Google Play 开发者帐号下发布的应用集的 ID。
例如,假设您在 Google Play 开发者帐号下发布了两个应用,并且这两个应用都通过 Google Play 商店安装在同一设备上。这两个应用在该设备上共享相同的应用集 ID。即使应用使用不同的密钥签名,ID 也相同。
应用范围
在以下任何条件下,应用集 ID SDK 会返回在给定设备上特定于调用应用本身的 ID
- 该应用是由 Google Play 商店以外的安装程序安装的。
- Google Play 服务无法确定应用的 Google Play 开发者帐号。
- 该应用安装在没有 Google Play 服务的设备上。
不要依赖应用集 ID 的缓存值
在以下任何条件下,设备上给定一组 Google Play 商店安装应用的应用集 ID 都可能被重置
- 共享相同 ID 值的应用组超过 13 个月未访问应用集 ID API。
- 给定一组应用中的最后一个应用已从设备中卸载。
- 用户执行了设备的恢复出厂设置。
您的应用应在每次需要时使用 SDK 检索 ID 值。
将应用集 ID SDK 添加到您的应用
以下代码片段显示了一个使用应用集 ID 库的示例 build.gradle
文件
dependencies {
implementation 'com.google.android.gms:play-services-appset:16.1.0'
}
以下示例代码片段演示了如何使用 Google Play 服务中的 Tasks API 异步检索应用集 ID
Kotlin
val client = AppSet.getClient(applicationContext) as AppSetIdClient val task: Task<AppSetIdInfo> = client.appSetIdInfo as Task<AppSetIdInfo> task.addOnSuccessListener({ // Determine current scope of app set ID. val scope: Int = it.scope // Read app set ID value, which uses version 4 of the // universally unique identifier (UUID) format. val id: String = it.id })
Java
Context context = getApplicationContext(); AppSetIdClient client = AppSet.getClient(context); Task<AppSetIdInfo> task = client.getAppSetIdInfo(); task.addOnSuccessListener(new OnSuccessListener<AppSetIdInfo>() { @Override public void onSuccess(AppSetIdInfo info) { // Determine current scope of app set ID. int scope = info.getScope(); // Read app set ID value, which uses version 4 of the // universally unique identifier (UUID) format. String id = info.getId(); } });