3

App版本升级


前言

    App的开发总会面临着新功能的迭代和Fix Bug,这个时候的App就需要进行升级并且及时通知用户更新。对于更新的一些小功能,考虑到用户所处环境可能不具备更新条件,一般不要求用户即刻的去升级App,只需要及时通知到用户就够了。但是如果此次更新舍弃了大部分旧功能的需求或是Fix重大Bug的情况下,就需要让用户强制进行升级,否则就无法正常使用app。

    不过现在Apple不允许以弹窗的方式告知用户更新,在审核时发现会被据回,Apple更希望看到的是在用户手机连接Wifi的时后台自动进行升级。但是如果用户关闭了自动更新,或是一直未连接到wifi,此时app修复了严重bug需要强制升级的话就行不通了。所以如今需要一些策略来进行App的弹窗控制升级。


目录

  • 两种版本控制方式

  • 实现和注意

  • 获取appid的方法

两种版本控制方式

1.调用iTunes接口进行版本控制

介绍:

    AppStore上的每个App都唯一对应一个AppID,我们可以通过调用下面两个接口任一个来获取应用当前的版本信息。
http://itunes.apple.com/cn/lo...
http://itunes.apple.com/looku...
(其中的appid要替换成你自己的appid号,如QQ的appid为444934666)

    由于新版本的App在通过审核之后AppStore上该App的版本信息才会更新,所以可以通过利用该时间差来进行版本控制。

例子:

    比如当前AppStore上App版本为2.0,此时需要进行审核的新版本为3.0。因为尚未通过审核,所以在审核人员操作3.0版本的App时,App从iTunes的接口获取到的版本号信息依旧为2.0,通过判断3.0 > 2.0,所以审核人员在操作3.0版本的App时并不会弹出需要升级的提示。
    在App上架后,当用户在操作App时,App从iTunes的接口获取到的版本号信息变成了3.0,此时将会通知用户进行升级。

优点:
  1. 不需要自己定义接口,使用方便;

  2. 更新时间的控制比较准确。只要新版本上架,用户打开app时就能看到更新提示。

缺点:
  1. 不能自定义升级类型。因为调用的是itunes的接口,无法控制接口返回数据,所以不能在“选择升级”和“强制升级”之间进行自定义控制。

2.调用自己服务端接口进行版本控制

介绍:

第一种方式不能自定义升级类型,其根本原因在于无法自定义接口的返回数据,所以我们可以定义接口,在自己服务端后台维护一份app版本信息,返回数据中我们可以返回一个字段专门用来控制是否进行强制升级控制。

优点:
  1. 自定义程度高,可自定义升级类型、是否显示弹窗等等。后续还可以建立一个内部的app版本控制平台。

缺点:
  1. 需要新增接口;

  2. 需要及时的更新版本信息。

3.总结

通过上述的对比,其实我觉得第二种方案的缺点可以忽略,一般app都会有自己的服务端,所以在工作量允许的范围内可以考虑第二种方案,毕竟需要应对大版本迭代或是发生重大Bug的情况。其实如今有很多的问题都可以通过热更新方案及时解决,不过热更新不是万能的,强制更新可以作为另一层保障。

  1. 对于无服务端或服务端不是由自己搭建的app,或是对bug的容忍度较大的app,可以考虑第一种方案。

  2. 在时间允许的前提下,对于有成熟服务端的app可以尽量考虑第二种方案。


实现和注意

实现:
1.在app启动回调中触发检查更新方法;
2.调用接口获取最新的版本信息;
3.判断需要更新后弹出alert提示。

对于调用itunes接口的方案:
    接口返回数据里的version字段为版本号,trackViewUrl字段为下载链接,判断version需要更新后使用代码调用safari打开trackViewUrl对应的链接即可。
比如QQ:@"version": @"6.6.9","trackViewUrl": "https://itunes.apple.com/cn/app/qq/id444934666?mt=8&uo=4"

对于自定义更新的方案:
    可通过自己定义的接口字段来判断是否升级、新版本下载链接、升级类型等。

附github地址:https://github.com/MagicianMa...

1.方案一

clipboard.png

2.方案二

clipboard.png

3.弹窗处理

clipboard.png

需要注意的地方:
  1. 对于自己服务端维护的接口,app的下载地址或其他信息可以通过第一种方案获取后保存到数据库,下载地址要在app上架后查看是否有改变并及时更新。

  2. 强制升级的实现,可在alert的点击事件中再弹出alert来实现控制。

  3. 如果用户在app打开时,通过关闭网络数据来避掉升级提示,需要进行一些控制。比如,可以在基类控制器viewDidLoad:方法中重新判断app版本信息,并可将版本信息维护在本地,以防止接口调用次数过多。


获取appid的方法

1.在itunes中搜索并找到应用后复制链接

clipboard.png

2.链接中id后的数字就是appid
clipboard.png

3.在postman中可以看到该app的相关信息

clipboard.png


花飞蝶舞剑
123 声望72 粉丝

Zcp大官人的iOS小站