您的位置:首页 > 其它

怎么使用命令对未签名的包进行签名

2017-02-27 23:12 281 查看
转自:http://jingyan.baidu.com/article/3c48dd3491d91fe10be358f4.html

在某些场合下,没有外在工具,需要对一个未签名的APK包进行签名,那就可以通过命令来对Android应用进行手动签名。


工具/原料

JDK+eclipse


方法/步骤

菜单菜单键,键入cmd命令进入命令模式。如图:





命令模式中,进入JDK的安装目录的Bin子目录下。(我的JDK安装在E盘,所以先进入E盘,然后再进入JDK安装目录)













通过keytool.exe 工具来创建keystore库.

输入以下命令:

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

-keystore mydemo.keystore

命令说明如下:

 -genkeypair  :指定生成数字证实

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

-keyalg:指定生成数字证书的算法  这里如RSA算法

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

-keystore :指定生成数字证书的存储路径。  (这里默认在keytool.exe 目录下)

回车 出现如图交互式界面   输入数字证书费密码 作者  公司等详细信息

如图 :





完成后,keystore库创建完成,你可以在指定的保存目录下找到 如图:





使用jarsigner命令对未签名的APK安装包进行签名。使用JDK安装目录下bin子目录下的jarsigner.exe工具来进行签名。

然后把未签名的apk也拷贝到此目录。如图:









使用如下命令进行签名:

jarsigner -verbose -keystore mydemo.keystore -signedjar

-Note.apk Notes.apk mydemo.keystore 

以上命令的说明:

-verbose:指定生成详细输出

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

-signedjar:该选项的三个参数为  签名后的apk包  未签名的apk包  数字证书别名

注意有效期哦。









签名后的apk  如图:





sdk目录下tool目录下使用zipalign.exe工具优化APK安装包。

将已经签名的apk包放在zipalign.exe同目录下   如图:





使用如下命令:

zipalign -f -v 4 -Note.apk -Notes.apk

命令说明:

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

-v  指定生成详细输出

4:指定档案整理基于的字节数  一般是4  也有基于32位的。

-Note.apk  :优化前APK

-Notes.apk   优化后的APK





运行命令后,在该目录下生成一个-Notes.apk,这个就是优化过的APK安装包

,该安装包可以对外发布。

如图:

如果能对你有帮助,希望你能收藏和支持。









END


注意事项

命令之间的空格区域


Android学习交流群:523487222


(如果您觉得有用,欢迎加入,一起学习进步)
点击链接加入群【Android学习群】

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: