由于经常使用到编译与反编译的相关命令,现将其记录下来以防忘记。
编译与反编译常用的命令。
1、解压APK
java -jar tools/apktool_2.2.3.jar d -f -s xxx.apk
2、反编译dex to jar
tools\dex2jar-2.0\d2j-dex2jar classes.dex -o classes.jar
3、编译jar to dex
tools\dex2jar-2.0\d2j-jar2dex classes.jar -o classes.dex
4、打包成APK
java -jar tools/apktool_2.2.3.jar b aaa -o game_unsign.apk
5、签名
jarsigner -verbose -digestalg SHA1 -sigalg MD5withRSA -keystore xxx.keystore -storepass "android" -keypass "android" -signedjar sign.apk game_unsign.apk alias
其他相关命令:
6、R文件生成
tools\aapt p -f -m -J ./gen -S aaa\res -I tools\android_21.jar -M aaa\AndroidManifest.xml
7、将R文件转为R.dex
java -jar \tools/jack.jar --classpath tools/android_21.jar --output-dex ./out ./gen
8、将dex文件转为smail文件
java -jar baksmali.jar -o ./smail ./classes.dex
9、获取最上层activity名称
adb shell dumpsys activity | findstr "mFocusedActivity"
10、查看resources.arsc文件的详细描述信息
aapt dump resources <apk的路径>
11、生成签名文件
keytool -genkey -alias <别名> -keyalg RSA -validity 20000 -keystore android.keystore
12、查看keystore签名文件信息
keytool -list -v -keystore ceshi.keystore
13、查看apk签名信息
keytool -printcert -file META-INF\CERT.RSA
14、签名 keystore 生成 keyhash
首先下载openssl.exe,并放置在jdk bin文件夹下。
http://vdisk.weibo.com/s/u7XBCkrmroyUI?from=page_100505_profile&wvr=6
然后执行以下脚本
keytool -exportcert -alias ceshi -keystore ceshi.keystore | openssl sha1 -binary | openssl base64