Estou tendo problemas para recuperar valores (em um dispositivo Android 9.0) de Preferências compartilhadas após reinstalar o aplicativo e ao permitir allowBackup = true.
<manifest ... >
...
<application android:allowBackup="true" ... >
...
</application>
</manifest>
De acordo com isso: https://developer.android.com/guide/topics/data/autobackup
As preferências compartilhadas devem ser restauradas?
SharedPreferences prefs = getSharedPreferences("TEST", MODE_PRIVATE);
String name = prefs.getString("name", "No name defined");//"No name defined" is the default value.
int idName = prefs.getInt("idName", 0); //0 is the default value.
SharedPreferences.Editor editor = getSharedPreferences("TEST", MODE_PRIVATE).edit();
editor.putString("name", "Elena");
editor.putInt("idName", 12);
editor.apply();
- Eu entrei na minha conta do Gmail no telefone (emulador) (API 27) e, ao acessar o aplicativo Drive, backups, dados do aplicativo, vejo 18 aplicativos como Youtube, Gmail etc. e também meu próprio aplicativo.
- Quando vou a "Configurações> Sistema> Backup", vejo os mesmos aplicativos e também meu próprio aplicativo. Eu carrego o aplicativo, o código sharedprefs é executado. Fecho o aplicativo e o removo da memória. E então eu pressiono o botão "Backup now":
Para verificar, posso ver meu aplicativo na lista e ele foi salvo há 0 minutos:
Depois, removo e reinstale o aplicativo e espero que os 2 valores (Elena e 12) estejam lá. Mas eles são apagados ...
Também tentei o mesmo via linha de comando, mas também não estava funcionando: https://developer.android.com/guide/topics/data/testingbackup.html#Preparing
adb shell
dreamlte:/ $ bmgr enabled
Backup Manager currently enabled
dreamlte:/ $ bmgr list transports
android/com.android.internal.backup.LocalTransport
com.google.android.gms/.backup.migrate.service.D2dTransport
* com.google.android.gms/.backup.BackupTransportService
dreamlte:/ $ bmgr backupnow my.package.name
Running incremental backup for 1 requested packages.
Package @pm@ with result: Success
Package nl.dagelijkswoord.android with progress: 1536/309248
Package nl.dagelijkswoord.android with result: Success
Backup finished with result: Success
dreamlte:/ $ dumpsys backup
Backup Manager is enabled / provisioned / not pending init
Auto-restore is disabled
No backups running
Last backup pass started: 1573804513565 (now = 1573806675410)
next scheduled: 1573819001046
...
1573806051616 : my.package.name
dreamlte:/ $ bmgr restore 1573806051616 my.package.name
No matching restore set token. Available sets:
35e84268c94b7d9c : SM-G950F
3a8e32898034f8af : SM-G950F
3e2610c4ea45fb96 : Nexus 5X
done
dreamlte:/ $ bmgr restore 35e84268c94b7d9c my.package.name
Scheduling restore: SM-G950F
restoreStarting: 1 packages
onUpdate: 0 = my.package.name
restoreFinished: 0
done
- Remover aplicativo
- Reinstale o aplicativo e verifique se os valores de SharedPreferences ainda estão lá.
- Os valores se foram ...
O comportamento também parece diferir nos dispositivos Samsung com Samsung Cloud, mas por enquanto vamos nos concentrar no estoque do Android.
ATUALIZAR:
Não estava mais funcionando porque eu fiz o downgrade da versão em build.gradle:
build.gradle:
versionCode 70
versionName "1.6.1"
Mesmo com android:restoreAnyVersion="true"
no AndroidManifest
só funcionaria quando a versão não foi rebaixada.