适配Android10.0+出现的问题及解决(不断迭代)
项⽬适配Android9.0+出现的问题及解决
关于
项⽬⼤概⽤到了百度地图sdk、定位权限、前后台服务等。
主要涉及的权限有⽹络权限、定位权限(包括后台定位)、存储权限。
项⽬的build版本 3.5.3
targetSdkVersion 29
其实⼀些9.0+的问题也适配到了
Java.lang.NoClassDefFoundError: Failed resolution of:
Lorg/apache/http/conn/scheme/SchemeRegistry
  这个在9.0以上运⾏闪退会报上⾯这个错误,解决办法:
在l⽂件的application标签⾥⾯加⼊如下:
&>
//加⼊如下
<uses-library android:name="org.apache.http.legacy" android:required="false"/>
</application>
The user 10154 does not meet the requirements to access device identifiers.
  ⾸先看⼀下我的错误代码:
/**
* 获取设备编号(对于GSM⼿机为IMEI;对于CDMA⼿机为MEID;不⽀持为null),需要权限android.permission.READ_PHONE_STATE
*/
@SuppressLint({"MissingPermission","HardwareIds"})
public static String getDeviceId(Context context){
TelephonyManager telephonyMgr =(TelephonyManager) SystemService(Context.TELEPHONY_SERVICE);
DeviceId()==null?"": DeviceId();
}
String deviceCode = DeviceId(getContext());
这⾥通过代码获取硬件标识符。
  解释⼀下:⾃ Android 10(API 级别 29)起,您的应⽤必须是设备或个⼈资料所有者应⽤,具有特殊运营商许可,或具有READ_PRIVILEGED_PHONE_STATE 特权,才能访问不可重置的设备标识符
这个是运⾏在Android10及以上会出现的闪退问题,解决办法:
1. 第⼀种,降低当前的targetSdkVersion,使其低于29(这显然和我写这篇⽂章的初⼼不符)
2. 第⼆种,就是加⼀个判断啦,如下:
private String deviceCode;
if(Build.VERSION.SDK_INT>28){
deviceCode = String(
}else{
deviceCode = DeviceId(getContext());
}
  这⾥是通过Android的⾃带ID取代这个硬件标识。。。
startForeground requires android.permission.FOREGROUND_SERVICE
在l添加以下权限代码:
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
(xxxx.server)’ ~ Channel is unrecoverably broken and will be disposed!
  ⼀般报这个错误的时候会有这个xxx,这个xxx就是我们报错的类⾥⾯的某些⽅法错误,所以在这个类⾥⾯进⾏排查,⽐如类型的强转、8.0的通知服务等。
No implementation found for int com.ls.JNITools.initClass
  我⼀开始也是闪退(8.0没有提⽰这个),Android10闪退了,经过⽇志收集,发现问题,我出现的问题是lib中的so库和build中ndk ⾥⾯的so库不⼀致,导致的缺失问题,我现在配置的是:
ndk {
access是什么意思啊了//cpu类型对应的.so库。
abiFilters'armeabi-v7a','x86','armeabi'
}
lib如下图:
Android9.0明⽂访问
  我们添加配置⽂件,使其⽀持明⽂访问(http)
  第⼀步新增network_l⽂件修改:
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
<base-config cleartextTrafficPermitted="true">
<trust-anchors>
<certificates src="system"/>
</trust-anchors>
</base-config>
</network-security-config>
  第⼆步,在l的application中添加对应标签:
android:networkSecurityConfig="@xml/network_security_config"
Android10+权限的申请问题
这⾥我采⽤的第三⽅申请框架,加上⼀些判断。
我项⽬中主要涉及的就是前后台定位权限、存储权限了。
第三⽅权限框架是郭霖⽼师的
定义⼀组权限申请列表:
//如果设置了target > 28,需要增加这个权限,否则不会弹出"始终允许"这个选择框
private static final String BACK_LOCATION_PERMISSION ="android.permission.ACCESS_BACKGROUND_LOCATION";
public static final String[] ARR_NEED_PERMISSIONS =new ArrayList<String>(){
{
add(Manifest.permission.ACCESS_COARSE_LOCATION);
add(Manifest.permission.ACCESS_FINE_LOCATION);
add(Manifest.permission.WRITE_EXTERNAL_STORAGE);
add(Manifest.permission.READ_EXTERNAL_STORAGE);
add(Manifest.permission.CAMERA);
add(Manifest.permission.CALL_PHONE);
add(Manifest.permission.READ_PHONE_STATE);
if(Build.VERSION.SDK_INT >28){
add(BACK_LOCATION_PERMISSION);
}
}
}.toArray(new String[0]);
PermissionX.init(this)
.permissions(ARR_NEED_PERMISSIONS)
.request(new RequestCallback(){
@Override
public void onResult(boolean allGranted, List<String> grantedList, List<String> deniedList){
if(allGranted){
//全部授权成功,做你想做的事情
}else{
ToastUtils.show(R.string.permission_need);
}
}
});
补充:
  在新项⽬中我遇到了两个问题:
同时申请前后台定位权限有问题,需要先后申请,即先申请前台后申请后台定位权限
部分⼿机(Android11)获取⼿机信息(Manifest.permission.READ_PHONE_STATE)即使已经允许过了还是会提⽰被拒绝,这⾥我⽤的投巧的⽅法解决:
//在第三⽅框架被拒的⽅法返回⾥⾯添加判断即可,不然第⼀次权限申请会报拒绝了该权限,但其实去设置⾥⾯看到的是已经给了权限的
if(!checkPermissionMethod(Manifest.permission.READ_PHONE_STATE)){
// 执⾏操作。
_STATE},999);
}else{
}
/**
* 判断是否需要检测,防⽌不停的弹框
*/
public boolean checkPermissionMethod(@NonNull String permission){
return ActivityCompat.checkSelfPermission(this, permission)== PackageManager.PERMISSION_GRANTED;
}
Android10+存储域变化
  部分⼿机(oppo的android11某机型)因为定制化的问题,⽤户⽆法查看data/下的⽂件内容,导致我们经常会使⽤的拍照存图⽚啊之类的存储会崩溃,⽽某些过低的版本的⼿机(5.0)在新的存储⽅法中⼜会崩溃,所以也需要适配:
if(Build.VERSION.SDK_INT<=Build.VERSION_CODES.M){
//这个是存储在app私有⽬录⾥⾯的,随着app卸载⼀起删除
savePhotoDir =ExternalFilesDir("xxx_Photos")+"";
}else{
//华为⼿机没有这个问题,oppo的部分⼿机上有,所以只能⽤原来的
savePhotoDir = ExternalStorageDirectory()+"/xxx_Photos";
}
               写的稍微有点仓促,可能会有遗漏或是问题,有问题欢迎批评指正留⾔

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。