我的新书《Android App开发入门与实战》已于2020年8月由人民邮电出版社出版,欢迎购买。点击进入详情
升级
升级是App必须预备的功能。
通过内置的升级功能,能够将最新版本的app推送给用户,方便用户直接在app内升级,增大新版本的覆盖比率。这样就不需要用户再去官网或者应用市场更新,影响新版本的升级效率。
升级功能必须提到的是强制升级。
什么情况下需要用到强制升级呢?那就是在低版本不可用的时候。
低版本不可用一般存在以下几种情况:
- 低版本不能和高版本兼容。
比如高版本新增了字段,低版本无法解析;又比如高版本新增了一个功能,但是低版本上无法看到这个功能的效果。 - 后台不再支持低版本接口。
app有重大升级,从v1升级到v2,v2接口相比v1有重大变化,那么服务器需要维护两套接口。当新版本用户覆盖率达到一定比例后,可以放弃v1旧接口的维护,通过强制升级提示旧版本用户升级到最新版本。 - 某些必须升级的情况
- 旧版本app存在漏洞。
漏洞会直接影响到app的安全,导致用户隐私和app的数据被盗取和非法利用。那么这些存在漏洞的版本就必须要强制升级。
还有一些漏洞当时发版的时候可能并未被发现,在使用过程中才暴露出来,那么这种情况下也需要及时通过强制升级来规避风险。 - 功能缺陷
有时候一些bug在测试的时候没有被发现,上线后发现这些bug会严重影响用户体验。那么这种情况下也必须通过强制升级来弥补。 - 证书过期
https的客户端证书,一般有效期2到3年,那么就会存在证书到期从而导致app无法进行网络连接的情况。这种情况一般我们会提前一段时间更新证书,然后放置在新版本的app中,用户升级即可。但是也有用户一直使用旧版本不升级。所以如果遇到这样的情况,也必须通过强制升级解决。
- 旧版本app存在漏洞。
功能开关
所谓的功能开关,就是能够控制app的某些功能的配置。这些配置通常是在服务器后台配置,然后客户端通过接口获取,然后进行配置。
在实际开发过程中,涉及到多个部门的合作,比如有一个商城的功能,可能在app发版的时候还没上线,那么我们可以在后台配置不显示,等到商城上线后,在后台配置开启,那么app中就可以显示这个商城。
比如后台可以通过配置Key-Value的形式:
Key: tab_mall_show
Value: {“isShow”:“0”} // 0表示显示,1表示隐藏
那么客户端就可以通过tab_mall_show这个参数获取对应的值,然后决定是否显示或者隐藏。
由于客户端需要通过网络获取配置信息,那么这个就涉及到网络获取成功或者失败的情况。成功则好,如果失败呢,是否需要有一个默认值呢?我们用下图来描述如何处理这一过程:
可以看到,获取网络配置和读取本地配置缓存是并行的,网络数据获取到后保存到本地配置缓存中;而使用的时候也是从本地配置缓存中读取,如果没有,这种情况一般就是第一此使用,可以使用本地hard code的配置,如果有,那么直接使用。
通用弹框
通用弹框主要用来解决一些通用的信息提示的问题。比如系统通知、账号在别处登录、账号异常被加入黑名单等等,因为是属于通用的功能,所以在开发app的时候需要具备。
另外涉及到通用弹框,也就是我们所说的全局弹框,要求用户在app的任何地方都能收到这个弹框,可以参考下面的文章:
Android全局对话框的三种实现
旧版本和新版本字段兼容
比如app v1.0版本定义了5种type,v1.0的app会对这5种type进行了对应处理;
app v2.0版本type增加了一个,v2.0的app同样也会对这六种type进行处理;
现在有个问题就是,如果v2.0版本的app将这新增的type发送给v1.0版本的app的话,v1.0版本app如果没有处理的话,那将不会有任何反应。所以我们在低版本app中,需要增加对未知type的处理,比如加一个判断,不在这5种type中的话,提示“当前版本不支持的消息,请升级到最新版本”。
extension扩展字段
扩展字段专门用来处理某个业务可以扩展的内容,而无需改动和扩展字段同层级的字段信息。
扩展字段的值也需要是Json字符串格式。
比如有一段IM消息的接口内容如下:
{
"uid":10000,
"name":"Jack",
"avatar":"https://www.baidu.com/img/bd_logo1.png",
"msg":"hello",
"msgType":21,
"extention":{
"from":"USA",
"signature":"love life!"
}
}
同级的uid、name、avatar、msg、msgType是固定字段,extention里面的字段是可以扩展的,以后如果有IM相关业务变化可以在extention里面新增字段即可。
权限管理
从android 6.0开始,也就是API Level >= 23,增加了权限检查功能。
权限检测生效条件:
- targetSdkVersion和compileSdkVersion >= 23;
- 运行的Android系统 >= 6.0;
两条必须同时满足。
如果app的targetSdkVersion和compileSdkVersion >= 23,而且又运行在>= 6.0的Android系统上,但是app中没有加入权限检测的代码,这样app请求的权限默认都会关闭,比如存储权限。那么app极有可能在运行的时候因为权限没有获取到而崩溃。而用户没有得到提示,不知道是什么原因引起的,给用户带来了不好的体验。
出于安全考虑,app中添加权限管理也是现在app开发过程中必备的功能之一。
域名替换
考虑到域名失效(比如域名过期失效、域名被限制使用等),需要app能够通过一个配置接口获取最新的域名,从而能将现有域名批量替换成最新的域名。这样就可以在不重新发布app的情况下继续使用。
比如获取域名替换接口的返回值如下格式:
{
"data": [{
"new": "test1.new.com",
"old": [
"test1.old1.com", "test1.old2.com"
],
"enable": true
},
{
"name": "test2.new.com",
"old": [
"test2.old.com"
],
"enable": true
}
]
}
new表示替换成的域名,old表示旧域名,enable表示是否替换。
其它
比如统计系统、崩溃系统、推送系统、分享、支付等等,根据实际需求配置。