Android程序签名详解、打包、发布到Google play步骤 . 分类: CNDN李伟 CSDN android android应用签名 android应用发布 google play发布 2012-09-03 12:49 8674人阅读 评论(0) 收藏 举报 androidgoogle工具eclipsedos优化 目录(?)[+] 本文主要讲解Android应用程序签名相关的理论知识,包括:什么是签名、为何要给应用程序签名、如何给应用程序签名等。 一、什么是签名? 若是这个问题不是放在Android开发中来问,若是是放在一个普通的版块,我想你们都知道签名的含义。可每每就是将一些生活中经常使用的术语放在计算机这种专业领域,你们就开始迷惑了。计算机所作的事情,或者说编程语言所作的事情,不正是在尽量地模拟现实吗?因此,计算机中所说的签名和生活中所说的签名在本质上是同样的,它所起到的做用也是一致的! 让咱们来看看,在现实生活中的签名。好比下面这张图片: 这是女星孙俪的签名。签名就意味着在纸上或别处写下本身的名字,或者说在某处打上一个标记做为你本身的一种特有的标识,当别人看到这个签名的时候,他会知道这是和你有关的,而不是其它人。 二、为何要给Android应用程序签名? 若是只能用一句简单的话语来回答这个问题的话,我会说:“这是Android系统所要求的”。 Android系统要求每个Android应用程序必需要通过数字签名才可以安装到系统中,也就是说若是一个Android应用程序没有通过数字签名,是没有办法安装到系统中的!Android经过数字签名来标识应用程序的做者和在应用程序之间创建信任关系,不是用来决定最终用户能够安装哪些应用程序。这个数字签名由应用程序的做者完成,并不须要权威的数字证书签名机构认证,它只是用来让应用程序包自我认证的。 三、为何我开发的Android应用程序没有作什么签名也能在模拟器和手机上运行? 你没有给Android应用程序签名并不表明Android应用程序没有被签名。为了方便咱们开发调试程序,ADT会自动的使用debug密钥为应用程序签名。debug密钥?它在哪?debug密钥是一个名为debug.keystore的文件,它的位置: 系统盘符:/Documents and Settings/liufeng/.Android/debug.keystore “liufeng”对应于你本身的windows操做系统用户名,怎么样,是否是已经找到它了。这也就意味着,若是咱们想拥有本身的签名,而不是让ADT帮咱们签名的话,咱们也要有一个属于本身的密钥文件(*.keystore)。 四、Android应用程序签名步骤 1)准备工做 apk的签名工做能够经过两种方式来完成: 1)经过ADT提供的图形化界面完成apk签名; 2)彻底经过DOS命令来完成apk签名 我比较喜欢第2)种方式,因此下面将讲解如何经过命令的方式完成apk签名。 给apk签名一共要用到3个工具,或者说3个命令,分别是:keytool、jarsigner和zipalign,下面是对这3个工具的简单介绍: 1)keytool:生成数字证书,即密钥,也就是上面说到的扩展名为.keystore的那类文件; 2)jarsigner:使用数字证书给apk文件签名; 3)zipalign:对签名后的apk进行优化,提升与Android系统交互的效率(Android SDK1.6版本开始包含此工具) 从这3个工具的做用也能够看出,这3个工具的使用顺序。一般咱们本身所开发的全部应用程序,都是使用一样的签名,即便用同一个数字证书,这就意味着:若是你是第一次作Android应用程序签名,上面的3个工具都将用到;但若是你已经有数字证书了,之后再给其它apk签名时,只须要用到jarsigner和zipalign就能够完成。 为了方便使用上面3个命令,首先须要将上面3个工具所在路径添加到环境变量path中(我说的是为了方便使用,没有说必需要这么作)。怎么配置环境变量就不在此讲解了,这里须要说一下这3个工具默认所在的路径: 1)keytool:该工具位于jdk安装路径的bin目录下; 2)jarsigner:该工具位于jdk安装路径的bin目录下; 3)zipalign:该工具位于Android-sdk-windows/tools/目录下 不知道你们是否注意到keytool和jarsigner两个工具是jdk自带的,也就意味着生成数字证书和文件签名不是Android的专利;另外从字面上理解jarsigner也能猜得出该工具主要是用来给jar文件签名的。 2)生成未经签名的apk文件 既然咱们要本身对apk进行签名,就再也不须要ADT默认帮咱们签名了。如何获得一个未经签名的apk文件呢?打开Eclipse,在Android工程名称上点击右键,依次选择“Android Tools” - “Export Unsigned Application Package ...”,而后选择一个存储位置保存便可。这样就获得了一个未经签名的apk文件。 3)使用keytool工具生成数字证书 keytool -genkey -v -keystore liufeng.keystore -alias liufeng.keystore -keyalg RSA -validity 20000 说明: 1)keytool是工具名称,-genkey意味着执行的是生成数字证书操做,-v表示将生成证书的详细信息打印出来,显示在dos窗口中; 2)-keystore liufeng.keystore 表示生成的数字证书的文件名为“liufeng.keystore”; 3)-alias liufeng.keystore 表示证书的别名为“liufeng.keystore”,固然能够不和上面的文件名同样; 4)-keyalg RSA 表示生成密钥文件所采用的算法为RSA; 5)-validity 20000 表示该数字证书的有效期为20000天,意味着20000天以后该证书将失效 在执行上面的命令生成数字证书文件时,会提示你输入一些信息,包括证书的密码,示例以下: 4)使用jarsigner工具为Android应用程序签名 jarsigner -verbose -keystore liufeng.keystore -signedjar notepad_signed.apk notepad.apk liufeng.keystore 说明: 1)jarsigner是工具名称,-verbose表示将签名过程当中的详细信息打印出来,显示在dos窗口中; 2)-keystore liufeng.keystore 表示签名所使用的数字证书所在位置,这里没有写路径,表示在当前目录下; 3)-signedjar notepad_signed.apk notepad.apk 表示给notepad.apk文件签名,签名后的文件名称为notepad_signed.apk; 4)最后面的liufeng.keystore 表示证书的别名,对应于生成数字证书时-alias参数后面的名称 5)使用zipalign工具优化已签名的apk(非必须但建议这么作) zipalign -v 4 notepad_signed.apk notepad_signed_aligned.apk 说明: 1)zipalign是工具名称,-v表示在DOS窗口打印出详细的优化信息; 2)notepad_signed.apk notepad_signed_aligned.apk 表示对已签名文件notepad_signed.apk进行优化,优化后的文件名为notepad_signed_aligned.apk 说明:若是你之前的程序是采用默认签名的方式(即debug签名),一旦换了新的签名应用将不能覆盖安装,必须将原先的程序卸载掉,才能安装上。由于程序覆盖安装主要检查两点: 1)两个程序的入口Activity是否相同。两个程序若是包名不同,即便其它全部代码彻底同样,也不会被视为同一个程序的不一样版本; 2)两个程序所采用的签名是否相同。若是两个程序所采用的签名不一样,即便包名相同,也不会被视为同一个程序的不一样版本,不能覆盖安装。 另外,可能有人可能会认为反正debug签名的应用程序也能安装使用,那也没有必要本身签名了嘛。千万不要这样想,debug签名的应用程序有这样两个限制,或者说风险: 1)debug签名的应用程序不能在Android Market上架销售,它会强制你使用本身的签名; 2)debug.keystore在不一样的机器上所生成的可能都不同,就意味着若是你换了机器进行apk版本升级,那么将会出现上面那种程序不能覆盖安装的问题。不要小视这个问题,若是你开发的程序只有你本身使用,固然无所谓,卸载再安装就能够了。但要是你的软件有不少使用客户,这就是大问题了,就至关于软件不具有升级功能! 》》》》》》》》》》》》》》》》》》》》》关于应用程序在Google Market 如今称为 Google Play上发布的步骤《《《《《《《《《《《《《《《《《《《《 写了一段时间的android应用了,只是在本身手机上面安装。 上周申请了android developer,须要一次性25美圆的程序开发注册费用。费用须要用google checkout,因此还要先申请google checkout。国内的信用卡通常都支持VISA,能够以香港地址做为付款地址注册成功。注册成功后,还能够向google购买一部用于开发的手机。 这样就能够进入android market发布主页了。这是我发布第一个应用后的截图: image 开发的是一个测试用的示例,见写了一个android带动画翻页效果的程序。 签名前须要了解的 首先须要知道,android market发布应用程序,没有人为的审核过程,若是符合要求,只要提交,将马上生效。 应用程序须要通过签名(sign)才能够发布,签名的主要做用是,让别人知道这个程序是你经过哪一个android开发者账号发布的。 签名将生成一个二进制的私钥文件(private key)。其实若是使用windows+eclipse adt开发,在用户目录下: .android\debug.keystore 路径下的文件,就已是一个私钥了,只不过这是debug用的私钥。即,android不能安装没有签名的APK,若是经过debug方式(开发者经过usb链接)安装APK,实际上生成的APK是使用debug签名的。使用debug私钥签名的APK文件没法发布到android market。 公钥和私钥,是非对称密钥体系中的概念。在这里的基本原理是用户可经过本身的私钥加密数据(应用程序中的指纹部分),数据能够经过公钥解码看到,主要目的是确保信息来源不被篡改。 生成私钥文件的步骤 签名很简单,使用的工具在JDK的bin目录下,keytool.exe。命令以下: keytool.exe -genkey -v -keystore 私钥的文件名 -alias 本身起个别名 -keyalg RSA -validity 10000 这里面除了汉字部分,均可以不动。运行该命令,会有交互的提示,相似下面: image 这样就会生成一个私钥文件,该文件要妥善保管,防止被别人冒用。 其实生成私钥也可使用eclipse adt插件,界面和下面签名应用程序的界面是同一个。 使用私钥文件签名应用程序 使用eclipse adt能够很方便的生成带签名的应用程序。 image 而后: image 这里要选择刚才生成的私钥文件,并输入正确的生成私钥的密码。 而后: image 输入别名的密码。 再下一步,就简单了,选择生成文件的路径便可。 image 发布应用程序 主要是上传应用程序文件,相关文件,好比屏幕截图,还有就是程序的文字描述等。 image 这部分上传文件就不说了,主要是屏幕截图,遇到点儿小麻烦,这里只支持两种尺寸的图片,个人nexus one 480×800竟然没有,只好用480×854的格式,须要用软件为截图修改一下尺寸(多了一点儿空白)。不然上传后会提示错误。 image 这部分,可能须要增长好比中文预研的介绍,可是没有简体中文,用的是繁体中文语言。 image 最后,勾选赞成google的要求。发布便可。 立刻就能够在android market上看到本身发布的应用。 imageandroid