Android系统版本适配

1.Android发展简史
Android官方文档:https://developer.android.google.cn/about/versions/pie
Android操作系统是一个由Google和开放手持设备联盟共同开发的移动设备操作系统,其最早的一个版本Android 1.0 beta发布于2007年11月5日,如今已经走过十多个年头。
咱们从Android发展史倒序说起。
Google I/O 2019大会:发布Android10.0:AndroidQ名字为(Android Q Beta),对应的API:29.
Google I/O 2018大会:发布Android9.0:AndroidP名字为Pie派/馅饼,对应的API:28。
Google I/O 2017大会:发布Android8.0:AndroidO名字为Oreo奥利奥,对应的API:26。
Google I/O 2016大会:发布Android7.0:AndroidN名字为Nougat牛轧糖,对应的API:24。
Google I/O 2015大会:发布Android6.0:AndroidM名字为Marshmallow棉花糖,对应的API:23。
Google I/O 2014大会:发布Android5.0:Android L名字为Lollipop“棒棒糖”,对应的API:21。

二:本文主要内容
1.Android 6.0运行时权限申请
2.Android 7.0 文件共享异常解决方案
3.android 8.0 通知
4.后台执行限制,startService会异常
5.隐式广播问题
6.各版本相关细节内容

三:Android P 9.0 版本28适配
1.Android P 限制了明文流量的网络请求,非加密的流量请求都会被系统禁止掉。Android 9.0强制使用https,会阻塞http请求,如果app使用的第三方sdk有http,将全部被阻塞。
解决方案:

解决方案:在资源文件新建xml目录,新建文件
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
 <base-config cleartextTrafficPermitted="true" />
</network-security-config>

清单文件配置:
<application
 android:networkSecurityConfig="@xml/network_security_config">
 <!--9.0加的,哦哦-->
 <uses-library
 android:name="org.apache.http.legacy"
 android:required="false" />
 </application>
 但还是建议都使用https进行传输

2:前台服务
针对 Android 9 或更高版本并使用前台服务的应用必须请求 FOREGROUND_SERVICE 权限。 这是普通权限,因此,系统会自动为请求权限的应用授予此权限。如果针对 Android 9 或更高版本的应用尝试创建一个前台服务且未请求 FOREGROUND_SERVICE,则系统会引发 SecurityException。

3:其他Api的修改
java.lang.IllegalArgumentException: Invalid Region.Op - only INTERSECT and DIFFERENCE are allowed
if (Build.VERSION.SDK_INT >= 26) {
canvas.clipPath(mPath);
} else {
canvas.clipPath(mPath, Region.Op.REPLACE);
}

四:Android O 8.0 版本26适配
1.通知栏
Android 8.0 引入了通知渠道,其允许您为要显示的每种通知类型创建用户可自定义的渠道。用户界面将通知渠道称之为通知类别。针对 8.0 的应用,创建通知前需要创建渠道,创建通知时需要传入 channelId,否则通知将不会显示。
解决方案:https://blog.csdn.net/weixin_37292229/article/details/76186696
2. 后台执行限制
如果针对 Android 8.0 的应用尝试在不允许其创建后台服务的情况下使用startService() 函数,则该函数将引发一个 IllegalStateException。因为无法得知系统如何判断是否允许应用创建后台服务,所以我们只能简单的try-catch startService,保证应用不会crash。
异常信息:

java.lang.IllegalStateException: Not allowed to start service Intent ,app is in background uid UidRecord

3. 允许安装未知来源应用
针对 8.0 的应用需要在 AndroidManifest.xml 中声明REQUEST_INSTALL_PACKAGES 权限,否则将无法进行应用内升级。

<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES" />

4.隐式广播
由于 Android 8.0 引入了新的广播接收器限制,隐式广播需要动态注册。否则,广播失效。我对隐式广播的理解:未指定广播接收器类名,通过 Action 发送。

5.桌面图标适配
针对 8.0 的应用如果不适配桌面图标,则应用图标在 Launcher 中将会被添加白色背景:https://mp.weixin.qq.com/s/WxgHJ1stBjokPi6lTUd1Mg

五:Android N 7.0 版本24适配:
1.应用间共享文件
对于面向 Android 7.0 的应用,Android 框架执行的 StrictMode API 政策禁止在您的应用外部公开 file:// URI。如果一项包含文件 URI 的 intent 离开您的应用,则应用出现故障,并出现 FileUriExposedException 异常。
比如Uri.fromFile(file),当我们尝试传递 file://URI可能会触发FileUriExposedException。
解决方案:
要在应用间共享文件,您应发送一项 content:// URI,并授予 URI 临时访问权限。进行此授权的最简单方式是使用 FileProvider 类。
具体解决方案:
https://blog.csdn.net/lmj623565791/article/details/72859156

2:APK signature scheme v2
Android 7.0 引入一项新的应用签名方案 APK Signature Scheme v2,它能提供更快的应用安装时间和更多针对未授权 APK 文件更改的保护。
1)只勾选v1签名就是传统方案签署,但是在7.0上不会使用V2安全的验证方式。
2)只勾选V2签名7.0以下会显示未安装,7.0上则会使用了V2安全的验证方式。
3)同时勾选V1和V2则所有版本都没问题。

3: org.apache不支持问题
// build.gradle里面加上这句话
defaultConfig {
useLibrary ‘org.apache.http.legacy’
}

4: SharedPreferences闪退
SharedPreferences read = getSharedPreferences(RELEASE_POOL_DATA, MODE_WORLD_READABLE);
//MODE_WORLD_READABLE :7.0以后不能使用这个获取,会闪退,修改成MODE_PRIVATE

六:Android M 6.0 版本23适配
1.动态权限申请
Android 6.0(API 级别 23)在清单文件声明权限之后,根据权限的敏感程度,有些权限被视为“常规”权限,因此系统会在安装应用时立即授予这些权限。还有些则被视为“危险”权限,因此需要用户明确授予相应的访问权限。所以,Android 6.0需要动态申请权限。如果应用需要一项危险权限,那么每次执行需要该权限的操作时,必须检查是否具有该权限。比如应用使用位置、相机、通信录需要提示用户允许使用这些权限。

运行时权限检查(Runtime Permisssions)
当App的targetSdkVersion>=23的时候, 需要用checkSelfPermission()用来检测App是否被授予了权限
可以用requestPermissions()用来请求权限 ,同时可以使用shouldShowRequestPermissionRationale()方法来向用户解释为什么需要这个权限.
具体实现:
https://blog.csdn.net/weixin_37292229/article/details/72358136

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值