对apk文件内容、数字证书、apk拆解、签名、重新打包等的一些实践

1、一个典型的apk文件通常有下列内容组成:
AndroidManifest.xml      全局配置文件
classes.dex                   Dalvik字节码
resources.arsc              编译后的二进制资源文件
META-INF\                   存放签名信息
res\                             存放资源文件

assets\                  可以存放配置文件或资源文件

2、数字证书,即密钥,也就是扩展名为.keystore的文件,生成一个数字证书的命令:
keytool -genkey -alias bdgame -keystore bdgame.keystore  -keyalg RSA -validity 20000

keytool命令位于JDK/bin目录下,是一个java数字证书的管理工具;

3、apk拆解
如果只是简单的查看apk文件内容,普通的RAR程序就可以打开apk;遇到需要用程序处理apk的情况下,推荐使用APKTool这款开源工具,附上链接:https://code.google.com/p/android-apktool/
附上APK拆解命令:apktool.bat d --no-src -f *.apk  temp

4、apk签名
命令:jarsigner -verbose -digestalg SHA1 -sigalg MD5withRSA  -storepass bdgame -keypass bdgame -keystore bdgame.keystore -signedjar demo-1234.apk .\output\unsigned.apk bdgame

jarsigner命令位于JDK/bin目录下,值得一提的是,我在批处理调用该函数时候,发现执行runtime.exec()后,一直未能成功返回process.waitFor(),就这么假死了,尝试了下,把参数 -verbose 去掉,执行就很顺利,感觉是输出内容太多,把程序堵了??

5、重新打包
命令:apktool temp temp.apk

拆包、再重新打包,为什么这么折腾啊?其实,这是为了修改渠道号,收到一个厂商的未签名包后,拆解这个APK包,修改渠道号,然后重新打包、签名,这么做,纯粹为了批量打渠道包。

转载于:https://my.oschina.net/xiaozhuang/blog/127897

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个工具前后用了好多天的时间查阅资料并不断修改才完成。本工具可以用于读取apk包的大量信息,无其他依赖。可以直接通过命令行运行,也可以当作架包使用。 命令行方式使用举例: 获取AndroidManifest.xml文件中定义的versionCode: java -jar ApkAnalysis.jar “apk路径” -versionCode 获取apk证书详情: java -jar ApkAnalysis.jar “apk路径” -certs 获取apk证书中的第一条的详情: java -jar ApkAnalysis.jar “apk路径” -certs 0 获取证书摘要(百度、高德地图等API中需要的那个SHA1): java -jar ApkAnalysis.jar “apk路径” -certs 0 SHA1 获取apk发布者信息: java -jar ApkAnalysis.jar “apk路径” -certs 0 issuer 获取apk声明的权限: java -jar ApkAnalysis.jar “apk路径” -permissions 当作为架包使用时,通过 ApkAnalysis apkAnalysis = ApkAnalysis.getApkReader(apkFilePath); 获取到ApkAnalysis的实例,然后就调用对应方法读取即可。相信都会使用自动补全等功能吧?那个会告诉你有哪些可用的方法,这里不例举了。 输入 java -jar ApkAnalysis.jar -help会给出如下提示,请慢慢研究。如果好用,请不吝评价一下,谢谢~至于源码么,会反编译的就反编译吧,我也拦不住的,纯Java写的,还是很好反编译的,也没有代码混淆过。感兴趣愿意一起交流的可以留言问我要,纯粹伸手党就算了。 Apk分析工具 v1.0.7 编译时JDK版本:1.6.0_33 当前JRE版本:1.6.0_33 作者:周骞 发布日期:2015-01-08 --------------------------------------------------- ApkAnalysis [-versionCode] [-versionName] [-packageName]... 可用的选项: -versionCode 版本号 -versionName 版本名称,如1.0.3 -packageName Apk包名 -certs [index] [MD5|SHA1|issuer|subject|validity] 获取证书的信息 -verify 校验apk文件签名,并列出未通过校验的文件 -permissions 获取apk所需的权限 -features 获取apk所需的特性 -activities [detail] 获取apk所含的Activity -services [detail] 获取apk所含的Service -receivers [detail] 获取apk所含的静态Receiver -content [name] 获取AndroidManifest.xml中的内容 -extract 抽取apk中的文件 -h[elp] 显示此帮助信息 --------------------------------------------------- 如在程序中引用本包,方法如下: ApkAnalysis apkAnalysis = ApkAnalysis.getApkReader(apkFilePath); 需要判断apkAnalysis是否为null,为null表示读取失败,不为null时即可调用getXX()获取数据

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值