将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 下的应用。
|