【需求解决系列之四】Android App 在线 自动更新(适配到9.0)

前言

其实每个Android App都应该有一个App在线更新的功能,这样才能及时的通知用户去更新最新版本的App。这个功能其实说起来比较简单,因为流程大家都懂!但是要真正的实现,还是要考虑很多东西的!因为项目的需要,对之前已经开源的库做了下升级重构,下面就这个做个简单的介绍。

系列

在工作之余,打算将一些常用的逻辑页面,模块,功能点做成library库,这样当有相似需求的时候,可以做到插拔式开发!现在系列中有以下内容

  • App内部自动更新-AutoUpdateProject
  • 选择城市-CitySelect
  • 扫描二维码条形码控件-ScanCode
  • 一键打开WebView控件-WebViewUtils
  • 简约动态权限申请库-FanPermission

正文

特点概述

  • 最大亮点,提供12种更新的样式,总有一个是你喜欢的类型!

  • 支持三种设置更新信息的方式,您可以直接传model,传json数据,或者直接配置请求链接,sdk会自主请求并发起app的更新,满足多方需求!

  • 文件下载支持断点续传,下载错误拥有重试机制;相同版本的apk只会下载一次,防止重复下载!

  • 使用接口方式获取数据时支持设置请求头,支持POST和GET请求方式,更灵活。

  • 调用者可以自定义UI实现更新功能。

  • 已适配Android 6.0,Android 7.0,Android 8.0,Android 9.0。

  • 提供强制更新,不更新则无法使用APP,同时可以根据后台返回受影响的版本号,可控制多个版本同时被强制更新。

  • 通知栏图片自定义

Github地址:

使用方式和注意事项都在这里,点赞咱们就是好兄弟,https://github.com/MZCretin/AutoUpdateProject

Demo体验

Demo下载

扫描二维码下载Demo:


【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第1张图片
erweima.png

效果预览

没有效果图的demo是没有灵魂的,没图你说个锤子哦!!!

【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第2张图片
type01.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第3张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第4张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第5张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第6张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第7张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第8张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第9张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第10张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第11张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第12张图片
type02.png
【需求解决系列之四】Android App 在线 自动更新(适配到9.0)_第13张图片
type02.png

过程分析与实现

过程分析与实现阐述

下面会对本次重构中的一些细节做些说明,但是不会提及到代码,既然已经提供了demo,觉得好用的兄弟还是去看demo吧!

过程分析

整个更新的逻辑大致可分成三步:

  • 获取更新信息,校验数据,确定是否需要更新

  • 展示更新信息,处理更新逻辑

  • 下载Apk文件,安装文件

用几句话描述就是:获取服务端最新的版本信息,最新Apk文件的下载路径,最新Apk文件大小信息,是否需要强更以及需要强更的版本号;对比当前App的版本信息,确定是否需要更新,确定是否需要强制更新;选择一个好看的样式展示这些信息;当用户点击更新按钮之后,检查本地是否已经下载好Apk文件,如果已经有下载好的文件,检查这个文件的大小和版本号是否与线上的apk的文件一致,不一致直接删除重新发起下载;另外本身如果没有下载完,会继续断点续传下载;获取到最终的安装文件之后,诱导用户去安装Apk文件并做好各个Android版本的兼容问题从而实现整个App的更新操作。

拆解分步阐述

  • 获取更新信息,校验数据,确定是否需要更新

    这里需要服务器端提供数据,我们需要知道当前生产环境中最新的版本是多少,通过这个最新的版本号,跟当前app的版本做比较,如果当前的版本要低于线上环境,则需要提示更新。

    对于数据的获取也是一个比较头疼的问题,正常情况下应该都是直接请求一个接口,获取服务器端最新的版本信息,app解析对应的字段数据;但是有些时候获取这些信息并不是通过接口来实现的,也可能只是一个云端txt文件,所以获取数据的方式不能太单一。

    这里提供了两大类方式,一种是提供api接口地址,sdk自主请求加解析;另外一种是直接提供解析好的数据给sdk,sdk直接处理更新逻辑,这种方式里面有两种小的方式,一种是提供数据源model,另外一种是提供一个json字符串,交给sdk帮忙解析和处理。这样就可以满足大多数场景下的使用了。

  • 展示更新信息,处理更新逻辑

    当上一步确定需要更新之后,才会走到这一步。当确定需要更新之后,为了增强功能,我们提供了强制更新的逻辑,这种场景其实很常见,比如新版新增了一个功能,老版本无法做同步兼容处理,这个时候就需要老版本强制更新到最新的版本。

    对于强制更新,我们还做了一个优化,可以对指定的版本强更,比如当前最新版本号为10,我们希望老版本中版本号为9的强制更新,其他更老的版本普通更新,我们就可以指定需要强更新的版本号,实现指定版本强更。

    对于展示更新信息来说,可能最大的痛点在于交互和样式,对于没有UI的朋友来说,可能怎么弄都觉得不好看,所以我们这里提供了12种UI样式,总有一个是你喜欢的吧!如果这12种你还是没有喜欢的,我们也提供了自定义UI的方式给你自己折腾。

  • 下载Apk文件,安装文件

    这一步可能就是核心了,有一些注意点以及优化的思路。

    下载文件之前我们需要检查存储权限,并做好Android6.0以上申请存储权限的准备,

    下载Apk文件使用的是filedownloader,用这个的好处在于他本身支持下载失败的重试机制,断点续传的机制,以及网络切换自动重启下载等优点,对文件的下载比较友好。

    下载文件还需要注意另外一点,我们在确定需要更新之后,在下载文件之前,我们需要检测下这个版本的app是否已经下载过了,如果下载过了就不要再重复下载了!对于是否下载好了有两个判断,一个对应这个版本的apk文件是否已经存在,第二个是这个apk文件的大小是否是正确的大小,因为有可能会出现文件下载异常的可能,这个时候需要删除掉这个apk去重新下载。

    还有一点就是在下载文件之前我们还是需要友好的检测下网络环境,如果是数据流量,还是需要提醒下用户当前是非wifi环境,优化用户体验。

    另外我们提供了通知栏进度的展示功能,默认是开启的,如果你不需要,可以在配置中关掉它。有这个通知栏的好处在于,当文件下载失败并重试三次依然失败之后,通知栏会显示下载失败,点击通知栏可以唤起重新下载的逻辑,仅此而已。

    当文件下载完成之后,我们需要处理的是Apk的安装问题,要注意Android不同系统版本之前的差异,并做好相关的兼容处理,我们已经兼容到Android9.0了,具体兼容细节大家移步源代码。

结语

首页,链接是 https://www.jianshu.com/u/123f97613b86

掘金首页,链接是 https://juejin.im/user/5838d57fac502e006c1708bc

Github首页,链接是 https://github.com/MZCretin

CSDN首页,链接是 http://blog.csdn.net/u010998327

我是Cretin,一个可爱的小男孩。

你可能感兴趣的:(【需求解决系列之四】Android App 在线 自动更新(适配到9.0))