Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Android_ID in Android O

We use the below code to get a unique ID:

String id = Settings.Secure.getString(mContext.getContentResolver(),
                 Settings.Secure.ANDROID_ID);

In the Android O changes guide we can see the below points:

Android O makes the following privacy-related changes to the platform. https://developer.android.com/preview/behavior-changes.html

The platform now handles identifiers differently.
Values of ANDROID_ID are now scoped per-app instead of per-user. The value of ANDROID_ID is unique for each combination of application package name, signature, user, and device. Two apps running on the same device no longer see the same Android ID, and so cannot correlate.

The value of ANDROID_ID does not change on package uninstall or reinstall, as long as the package name and signing key are the same.

The value of ANDROID_ID does not change if the package signing key changes due to an update.

For apps that were installed prior to the OTA, the value of ANDROID_ID remains the same unless uninstalled and then reinstalled.

If you wish to continue using Android ID for device-bound free trial protection, you can do so. Make sure that the package name and signature match.

For a simple, standard system to monetize apps, use Advertising ID. Advertising ID is a unique, user-resettable ID for advertising, provided by Google Play services.

My understanding of the above is that now the Android_ID going forward will be app bound rather than device bound. However I am confused about the below point:

For apps that were installed prior to the OTA, the value of ANDROID_ID remains the same unless uninstalled and then reinstalled. If you wish to continue using Android ID for device-bound free trial protection, you can do so. Make sure that the package name and signature match.

1) What does this mean? Unless my app is reinstalled it will continue having the legacy android_id, even if we send an update?

2) If you wish to continue using Android ID for device-bound free trial protection, you can do so. Make sure that the package name and signature match.: what does this mean?

like image 222
Sid Avatar asked Mar 10 '23 04:03

Sid


1 Answers

1) Imagine your app has the id abc when installed on an N device. Now when the device gets updated to O the device id returned to you will continue to be abc. However if the user uninstalls and reinstalls the app after upgrading to O, ANDROID_ID will change to some other value.

On the other hand if the app was installed on an O device and is then uninstalled and reinstalled the ANDROID_ID will remain the same.

2) It means that as long as the package name and signature remain the same the value of ANDROID_ID will remain the same. It will also remain the same if your app gets updated on an O device and the signature changes.

Essentially, android will now use the package name/ signature to generate the unique identifier on O.

like image 170
ashkhn Avatar answered Mar 16 '23 12:03

ashkhn