如何给apk文件签名
1.签名的意义
为了保证每个应用程序开发商合法ID,防止部分开放商可能通过使用相同的Package Name来混淆替换已经安装的程序,我们需要对我们发布的APK文件进行唯一签名,保证我们每次发布的版本的一致性(如自动更新不会因为版本不一致而无法安装)。
2.签名的步骤
a.创建key
b.使用步骤a中产生的key对apk签名
3.具体操作
方法一: 命令行下对apk签名(原理)
1)创建key,需要用到keytool.exe (位于jdk1.6.0_24\jre\bin目录下),使用产生的key对apk签名用到的是jarsigner.exe (位于 jdk1.6.0_24\bin目录下),把上两个软件所在的目录添加到环境变量path后,打开cmd输入
> keytool -list -alias CERT -keystore CERT.keystore
2)使用jdk的jarsigner工具对apk文件签名
例子:
为APK重新生成签名
1)、将证书复制到与需要重新签名的apk文件相同的目录下
2)、进入该目录下执行以下语句
jarsigner -verbose -keystore CERT.keystore -signedjar weibo_signed.apk |
命令解释:
jarsigner是Java的签名工具,JDK自带
-verbose参数表示:显示出签名详细信息
-keystore表示使用当前目录中的android.keystore签名证书文件。
--signedjar weibo_signed.apk netease_microblog_android_unsigned.apk表示签名后生成的APK名称为 weibo_signed.apk,未签名的APK Android软件名称为netease_microblog_android_unsigned.apk
CERT: 表示签名文件的别名,生成证书的时候有书写
执行以上操作之后在目录下生成了weibo_signed.apk ,经过自己签名的APK文件
方法二:使用Eclipse导出带签名的apk
Eclipse直接能导出带签名的最终apk,非常方便,推荐使用,步骤如下:
第一步:导出。
第二步:创建密钥库keystore,输入密钥库导出位置和密码,记住密码,下次Use existing keystore会用到。
第三步:填写密钥库信息,填写一些apk文件的密码,使用期限和组织单位的信息。
第四步:生成带签名的apk文件,到此就结束了。
第五步:如果下次发布版本的时候,使用前面生成的keystore再签名。
第六步:Next,Next,结束!
本文参考:http://www.cnblogs.com/qianxudetianxia/archive/2011/04/09/2010468.html
http://blog.csdn.net/shandong_chu/article/details/7672474
最新文章
- Dancing Links and Exact Cover
- 【HDU】1599 find the mincost route
- Mysql示例数据库employees.sql导入问题
- python内置模块(4)
- BZOJ 1455
- Poj(2349),最小生成树的变形
- Shell script之if...then
- [转载]C#中的WebBrowser控件的使用
- Linux free字段解析
- SSH+Ajax实现用户名重复检查(二)
- C++ Prime:decltype类型指示符
- 基于位运算符的IP和数值转换
- 20181117-python第二章学习小结-part2
- python3学习笔记11(函数)
- Java岗 面试考点精讲(基础篇01期)
- asp.net core 自定义404等友好错误页面
- 【Codeforces Round 1120】Technocup 2019 Final Round (Div. 1)
- 【问题解决:时区】连接MySQL时错误The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone
- testng运行失败,继续执行
- E-commerce 中促销系统的设计