Android开发中容易被忽视的一些注意事项
一、谨慎选择包名
包名(PackageName)就相当于一款应用在户口本上登记的名字,是系统用来区分不同应用的字段。重复的包名会被认为是同一款应用,不能同时安装在一个系统里。一般来说,包名建议使用域名反序。比如豌豆荚的网站域名是www.wandoujia.com,那么豌豆荚的一系列Android应用的包名就是com.wandoujia.***。这种约定俗成的办法可以最大程度地避免“撞名”的事故。
案例一
某个手机ERP客户端的开发者,在开发应用时使用了Adobe的工具,同时也参考了Adobe的官方教程,从而将应用命名为air.Main这样的通用包名,跟另一个游戏重名了。于是,在升级的过程中就产生了混乱……所以取名要慎重啊!
案例二
还有个开发者,不知为何给几个不同的应用都使用了同一个包名。于是“com.hexin.qs.app.android”这个包名,对应了“申国万银证券”、“中信建投手机证券”、“联讯证券手机炒股”等好几个完全不同的应用。带来的后果就是,用户不能在手机上同时安装这几个应用,而且在升级过程中也容易从一个应用升级到另一个应用上。所以,不能给好几个孩子取同一个名字啊!
二、一款应用只应该有一个签名
签名文件就相当于开发者的“身份证”,我们平时生活中应该只有一张身份证,那么在手机里也一样,签名也应该是唯一的。而且因为签名的加密机制,使复制和伪造签名变得几乎不可能,所以“豌豆洗白白”也是将签名作为判断是否官方版的最主要标准之一。
如果一个应用使用了不同的签名,那么对于用户来说,可能会造成应用无法升级,因为Android系统会在升级应用的过程中比对签名,不同的签名无法升级。如果用户选择强制升级的话,因为签名不同,所以需要先卸载旧版再安装新版,那么之前存在本地的应用数据、游戏记录等也会直接丢失。
案例一
就好像我们会不小心弄丢身份证,开发者也会不小心弄丢签名文件。我们曾遇到过四五例类似的例子,开发者找上门来说要求更换签名,原来是因为工程师离职把签名文件带走了,老板要不回来了,只好把原来的签名也全都改一遍。所以签名文件要保管好啊!
案例二
我们曾经统计过,网游“我叫MT”在各大市场上一共有48种不同的签名。据“我叫MT”的开发者说,他们是通过不同的签名来区分不同的渠道的,而一共放出过多少种签名难以统计。这么多个不同的签名文件,除了自己管理起来非常麻烦之外,也给用户的升级过程带来了困扰,一不小心升级到了不同签名的版本上,游戏记录就全部丢失了。
Android签名机制的目的是为了检验应用是否被人更改过,而不是为了让你区分渠道的。那么正常来说应该用什么方法来区分渠道呢?请看下一条。
三、使用xml配置文件来区分渠道
一般来说,我们在Androidmanifest文件中使用meta-data来区分渠道。例如:
<meta-dataandroid:name="CHANNEL"android:value="wandoujia"/>
每次正式打包完成后,修改android:value,再重新打包即可生成一个新的渠道包,所以:
不要再用签名来区分渠道了!
四、正确填写版本号
在Android应用中,有两个参数与版本号相关。其中,versionName表示版本名称,是字符串,versionCode表示版本号,是整型数字。
一般来说,用户直观看到的是versionName,所以这里应该填写形似“4.15.1”这样的版本号。而真正用来判断新版本旧版本的参数是versionCode。在应用发布第一个版本的时候,versionCode应该填1,然后每次发布的时候都递增,这样才是以规范的格式告诉各大市场你的应用的更新程度。
有的开发者在versionCode上非常随意,这个版本发布的时候碰上结婚纪念日,于是用老婆的生日当versionCode;下个版本发布的时候运气不太好,于是用自己的幸运数字当作versionCode……这样在用户看来的结果就是,明明从官网安装了最新的2.2.0版本,可是各大市场却提醒“升级到2.1.3版本”,越升级版本号越小了。
以上四件小事,虽然都比较琐碎,而且没什么技术含量,但却是很多入门的Android开发者容易忽略的问题。希望本文能帮助广大开发者,在写出好应用的同时,避免这些“坑”给应用带来不必要的损失。