Android APK如何签名

Android项目以它的包名作为唯一标识,如果在同一设备上安装两个相同的应用,后面安装的应用就会覆盖前面安装的应用。为了避免这种情况的发生,我们需要对作为产品发布的应用进行签名。

签名其实有两个作用:

(1) 确定发布者的身份。防止别人用相同包名来替换你已安装的程序。

(2) 确保应用的完整性。签名会对应用包中的每个文件进行处理,以确保程序包中的文件不会被替换。

在应用的开发和调试阶段,Eclipse的ADT插件或ANT工具会自动生成调试证书,对Android应用签名。但是,如果要正式发布一个Android应用的话,就必须使用合适的数字证书来给应用程序签名,不能使用ADT插件或ANT工具生成的调试证书来发布。

这有又两种方式对Android应用签名:

1.在Eclipse中对Android应用签名

(1) 右击Android项目,Android Tools-->Export Signed Application Package...

(2) 如果系统还没有数字证书,可以选择"Create new keystore",按如图格式填写数字证书的存储路径和密码。

(3) 填写数字证书的详细信息。

(4)指定生成签名后的APK安装包的存储路径。

签名证书制作完后,以后就可以直接使用该数字证书签名了。

(1)选择前面创建的keystore,输入创建keystore时的指定密码。

(2)选择前面创建时的别名yq的key,并输入创建该key时指定的密码,生成签名后的apk包。

 2.使用命令对APK包签名

在某些场合下, 我们可能需要对一个“未签名”的APK包进行签名,则可通过“命令”来对Android应用进行手动签名。

(1) 创建keystore库。JDK的安装目录下的bin子目录下提供了keytool.exe来生成数字证书。

在命令窗口输入:

keytool -genkeypair -alias yqkey.keystore -keyalg RSA -validity 100 -keystore yqkey.keystore

说明:

-genkeypair:指定生成数字证书。

-alias:指定生成数字证书的别名。

-keyalg:指定生成数字证书的算法。使用RSA算法。

-validity:指定生成的数字证书的有效期。

-keystore:指定所生成的数字证书的存储路径。

回车后,接下来将会以交互的方式让我们输入数字证书keystore的密码、作者、公司等详细信息。

该步骤只要做一次即可,一旦数字证书创建成功后,只要在该证书的有效期内,可以移植重复使用该证书。

(2) 生成未签名的APK安装包。在Eclipse中右击Android项目,Android Tools-->Export Unsigned Application Package...

(3) 使用jarsigner命令对未签名的APK安装包进行签名。JDK的安装目录下的bin子目录下提供了jarsigner.exe工具进行签名。在命令窗口输入:

jarsigner -verbose -keystore crazyit.keystore -signedjar Demo_yqkey.apk Demo.apk yqkey.keystore

说明:

-verbose:指定生成详细输出。

-keystore:指定数字证书的存储路径。

-signedjar:该选项的三个参数分别分签名的APK包、未签名的APK包、数字证书别名。

回车后,接下来将会以交互的方式让我们输入数字证书keystore的密码。

(4) 使用zipalign.exe工具优化APK安装包。zipalign.exe是Android自带的一个档案整理工具,它可用于优化APK安装包,从而提升Android应用与系统之间的交互效率,提升应用程序的运行速度。在命令行窗口输入:

zipalign -f -v 4 Demo_yqkey.apk

Demo_yqkey_zip.apk

说明:

-f:指定强制覆盖已有文件。

-v:指定生成详细输出。

4:指定档案整理所基于的字节数,通常指定为4,也就是基于32位进行整理。

Demo_yqkey.apk和Demo_yqkey_zip.apk,分别制定整理前的APK和整理后生成的APK。

生成的Demo_yqkey_zip.apk文件,就是签名完成且经过优化的APK安装包,该安装包可以对外发布了。

时间: 2024-11-04 07:47:04

Android APK如何签名的相关文章

android apk的签名和权限问题

一. android apk的签名问题(http://blog.csdn.net/lyq8479/article/details/6401093) 1.为什么要给Android应用程序签名?      如果只能用一句简单的话语来回答这个问题的话,我会说:“这是Android系统所要求的”.      Android系统要求每一个Android应用程序必须要经过数字签名才能够安装到系统中,也就是说如果一个Android应用程序没有经过数字签名,是没有办法安装到系统中的!Android通过数字签名来

在 java 1.8.0 版本的环境下,进行 android apk 的签名操作

注:文章参考了 android 开发者社区的签名指引说明文章,但由于在国内 android 开发者社区已经无法正常访问,因此在这里做下记录. 地址:http://developer.android.com/tools/publishing/app-signing.html#considerations 在开发 android 应用程序的时候,到最后程序都需要进行签名后才可以发布,目前针对 android 应用开发的 ide 一般都会自带了签名的功能,例如 android studio.eclip

读取Android APK文件签名的方法

在微信开放平台等申请API key 和secret时经常要用到apk文件签名,那么如何读取呢? 下面贴一下相关读取源码: 一共两个文件MainActivity和MD5, package com.lcg.gensinature; import android.app.Activity; import android.app.AlertDialog; import android.content.Context; import android.content.DialogInterface; imp

Android : apk系统签名的多种方法

方法一:使用自己的Android签名工具给apk重新签名: (1)该目录下有 media.pk8.media.x509.pem.platform.pk8.platform.x509.pem.shared.pk8.shared.x509.pem.testkey.pk8.testkey.x509.pem等签名文件,不同的签名文件,对应不同的权限.Android默认的签名文件为testkey.pk8.testkey.x509.pem. (2) Android自带的签名工具为 signapk.jar,

Android APK 手动签名

首先,如果没有签名密钥,先生成密钥: keytool -genkey -alias android.keystore -keyalg RSA -validity 20000 -keystore android.keystore 会一路提示你输入密码.签名信息等等,随意输入. 我这里的用户名和密码都是android 然后签名 jarsigner -keystore android.keystore -storepass android -keypass android XXX.apk androi

android apk jarsigner 签名打包

cmd 命令符打包: 规则:  jarsigner -verbose -keystore 签名路径 -signedjar 签名后的apk存放路径  未签名的apk 签名文件的别名 项目如我的项目是: C:\Program Files\Java\jdk1.7.0_45\bin> jarsigner -verbose -keystore C:\Users\jian_zhou\Desktop\d\cmstop.keystore  C:\Users\jian_zhou\Desktop\d\sgin_ne

android Apk 重新签名

1.将key文件和要重新签名的Apk文件放在同一个目录下. 2.cmd cd 到该目录下 3.jarsigner -verbose -keystore abc.keystore -signedjar 123x.apk 123.apk abc.keystore 其中: 第一个abc.keystore是key文件的名称, 第二个abc.keystore的别名. 123x.apk是重新签名后的apk, 123.apk 是原始的apk. 4.输入密码

android apk重新[签名]

1,删除之前的签名文件 用解压缩工具打开,删除 [META-INF] 文件夹 2,打开命令行窗口 3,[保证签名文件和apk在同一级目录下] 然后执行如下命令,将 (xx) 处替换自己的签名.apk 信息即可 jarsigner -verbose -keystore (签名文件 jks/keystore) -storepass (秘钥) -signedjar (签名后的 apk 名称 xx.apk) -digestalg SHA1 -sigalg MD5withRSA (要签名的 apk) (签

对 android apk 进行重新签名操作

注:如何进行 android apk 的签名,不是本文主要内容,如需了解签名先关步骤,可以参考我的以下这篇文章. 地址:http://www.cnblogs.com/LuQingshang/p/3926009.html 需求描述:在使用 Intellij idea 的情况下,不想通过编辑器提供的功能生成签名的 apk,因为每次要填写 apk 的名称,比较麻烦. 解决方案:idea 每次编译后,都会在 out 目录下生成两个 apk 文件,该两个 apk 文件都是可以安装执行的,因此选其中一个,进