SharedPreferences in credential encrypted storage are not available until after user is unlocked

将apk从android O(targetSdkVersion是23)升级到android R(targetSdkVersion是26)后

从android 11的原生代码里面将opp部分代码扒出来,但是会导致crash

提示

--------- beginning of crash
01-27 17:05:59.666  1479  1479 E AndroidRuntime: FATAL EXCEPTION: main
01-27 17:05:59.666  1479  1479 E AndroidRuntime: Process: com.anwsdk.service, PID: 1479
01-27 17:05:59.666  1479  1479 E AndroidRuntime: java.lang.RuntimeException: Unable to create service com.android.bluetooth.opp.BluetoothOppService: java.lang.IllegalStateException: SharedPreferences in credential encrypted storage are not available until after user is unlocked
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ActivityThread.handleCreateService(ActivityThread.java:4204)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ActivityThread.access$1500(ActivityThread.java:237)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1932)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.os.Handler.dispatchMessage(Handler.java:106)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.os.Looper.loop(Looper.java:223)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ActivityThread.main(ActivityThread.java:7656)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at java.lang.reflect.Method.invoke(Native Method)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: Caused by: java.lang.IllegalStateException: SharedPreferences in credential encrypted storage are not available until after user is unlocked
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ContextImpl.getSharedPreferences(ContextImpl.java:494)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ContextImpl.getSharedPreferences(ContextImpl.java:479)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:188)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at com.android.bluetooth.opp.BluetoothOppPreference.init(BluetoothOppPreference.java:87)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at com.android.bluetooth.opp.BluetoothOppPreference.getInstance(BluetoothOppPreference.java:73)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at com.android.bluetooth.opp.BluetoothOppService.onCreate(BluetoothOppService.java:209)
01-27 17:05:59.666  1479  1479 E AndroidRuntime: 	at android.app.ActivityThread.handleCreateService(ActivityThread.java:4192)

原因:在AndroidO及以上平台上,一个应用使用了SharedPreference的apk,且TargetSdk设置大于等于26,如果在设备刚开机时(用户未解锁),调用getSharedPreferences就会导致crash,从错误提示也可以看出跟user locked有关。源码如下

 

解决方法:

1、设置targetSdk为小于26。但是我们的程序有很多要26以上的才能用,所以不可行

2、开机处于user locked状态时避免使用SharedPreference,这个也不可行。

3、系统应用可以设置android:defaultToDeviceProtectedStorage=”true”,我们的蓝牙替换了原生的蓝牙,也是系统应用,所以使用这个方案

原因参考:https://blog.csdn.net/myfriend0/article/details/77094890

在启用了 文件级加密FBE 的设备上,每位用户均有两个可供应用使用的存储位置:

凭据加密 (CE) 存储空间:这是默认存储位置,只有在用户解锁设备后才可用。

设备加密 (DE) 存储空间:在直接启动模式期间以及用户解锁设备后均可用。

对于系统的应用,声明 android:defaultToDeviceProtectedStorage=”true” 可以把应用的默认存储空间设置为 /data/user_de/。因此,在用户没有输入凭据解密 CE 空间之前,系统只是加载 DE 下的应用。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值