命令行反编译重打包

1、下载apktool工具

下载地址:Apktool - How to Install

下载这两个文件放入同一个文件夹;

2、反编译apk

将需要反编译的apk文件放进ApkTool文件夹内,运行cmd,进入到ApkTool文件夹下;键入以下命令,执行成功会生成一个同名的文件夹;

apktool d demo.apk

加上 -s 表示不把dex文件反编译成smile语言,生成的为dex文件 ,可以方便后面查看源代码;

apktool d -s demo.apk

3、重新打包

将要反编译的apk文件放到apktool文件夹,打开cmd,进入ApkTool文件夹目录,执行命令:

apktool b demo -o demo2.apk

执行成功会生成一个demo2.apk

4、签名apk

重新打包后的apk需要重新签名,执行命令:

jarsigner.exe  -verbose  -keystore  xxx.keystore  -signedjar  demo2_signed.apk  demo2.apk  签名文件的别名  -digestalg   SHA1  -sigalg  SHA1withRSA

v1+v2签名

apksigner sign --ks 签名文件 --ks-key-alias 别名 --out 签名后的apk 待签名的apk

(注:mac下jarsigner去掉.exe)

5、优化apk

为了使apk在安卓系统上运行更快,签名完成后,建议对APK文件进行一次对齐操作,需要执行命令:

zipalign  4  demo2_signed.apk  new_demo2.apk

执行成功会生成一个new_demo2.apk

注:使用zipalign命令需要将zipalign的路径加入到系统环境变量当中,在SDK的\build-tools\22.0.1\目录下

6、验证签名是否成功

执行命令:

jarsigner  -verify  -verbose  -certs  new_demo2.apk

当输出  jar已验证,表示签名成功;

7、验证是否使用了v1和v2签名

apksigner verify -v --print-certs apk地址

 v1:true表示使用了v1签名

v2:false表示没有使用v2签名

8、命令行查看apk的包名、版本号等信息

aapt dump badging test.apk

9、命令行查看签名文件的SHA1值、MD5值

keytool -v -list -keystore keystore文件路径

10、查看.apk包里的签名详细

jarsigner -verify -verbose -certs app-release.apk

11、查看apk的SHA1、md5等值

//第一种、不需要解包
keytool -printcert -jarfile xxx.apk

//第二种、需要解包
keytool -printcert -file \META-INF\CERT.RSA

12、dex文件转为smali

java  -jar  baksmali-2.5.2.jar  disassemble  dex文件路径  -o  输出文件路径

java -jar baksmali-2.5.2.jar disassemble classes.dex -o smali

13、smali文件转为dex文件

java  -jar  smali-2.5.2.jar  assemble  smali文件路径  -o  输出dex文件路径

java -jar smali-2.5.2.jar assemble smali -o classes.dex

14、adb打印Error级别的日志 

//过滤Error级别的日志
//Log日志级别:
//V:(详细日志。默认的) D:(调试信息)I:(正常使用时的日志信息)W:(警告)E:(错误)
adb logcat *:E

//过滤关键字日志,例子为包名
adb logcat | grep 包名

//将所有日志保存到本地文件
adb logcat > /Users/Desktop/log.txt

15、查看手机CPU架构命令

adb shell getprop ro.product.cpu.abi

16、解压jar文件

jar -xvf jar包名字.jar

17、Mac磁盘相关命令

Mac命令查看整个硬盘的大小 :df -h  

Mac命令查看当前文件夹大小:du -sh

Mac命令查看当前目录下所有文件大小:du -sh *  

Mac命令查看当前目录下所有文件大小(按GB大小筛选):du -sh * | grep "G"

Linxu 删除文件:rm

Linxu删除文件或目录:rm -r

Linux强制删除文件或目录:rm -rf

获取linux下的进程id和进程名:jps

获取linux下详细的进程信息:ps -ef| grep mysql

Mac命令查看进程信息:

ps -ef | grep 进程名

Mac命令杀死进程:

sudo kill -9 PID
如:sudo kill -9 750

18、获取Android设备虚拟机最大内存,即oom超出限制的那个内存数

adb shell getprop | grep dalvik.vm.heapgrowthlimit

//APP运行的时候分配给虚拟机的初始空间大小
dalvik.vm.heapstartsize=8m
//初始分配给APP虚拟机的内存不够用的时候会自动扩张,这个值就是扩张的最大值。
dalvik.vm.heapgrowthlimit=192m
//应用的最大堆内存大小,这个值是APP使用大heap时的限定值。就是APP的mainfest文
//件中有声明 android:largeHeap=“ture”,这个时候,堆空间的最大值使用heapsize限定;没有声明largeHeap的APP,堆空间使用heapgrowthlimit限定。
dalvik.vm.heapsize=512m
//描述堆内存的利用率,是当前的有效变量所占内存和总内存的比值。
dalvik.vm.heaptargetutilization=0.75
//描述单次堆内存调整的最小值
dalvik.vm.heapminfree=2m
//描述单次堆内存调整的最大值
dalvik.vm.heapmaxfree=8m

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1) APKtool软件包 及签名tool APKtool软件包有2个程序组成:apktool.jar 和 aapt.exe 另外提供一个批处理文件:apktool.bat,其内容为: java -jar "%~dp0\apktool.jar" %1 %2 %3 %4 %5 %6 %7 %8 %9 运行apktools.jar需要java环境(1.6.0版本以上)。 apktool.jar用于解包,apktool.jar和aapt.exe联合用于打包。 signapk.jar 用于签名。 2) APK文件的解包 下面以解开Contacts.apk为例。首先把Contacts.apk Copy到当前工作目录下(例:Test)。在DOS下打入命令 apktool d Contacts.apk ABC 这里“d”表示要解码。Contacts.apk是要解包的APK文件。ABC是子目录名。所有解包的文件都会放在这个子目录内。 3) APK文件的打包 在DOS下打入命令 apktool b ABC New-Contacts.apk 这里“b”表示要打包 ABC是子目录名,是解包时产生的子目录,用来存放所有解包后的和修改后的文件。 New-Contacts.apk是打包后产生的新的APK文件。 4) 签名,不签名安装时可能提示如下错误: Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES] --- 没有签名,可以尝试test证书;签名方法见下面。 Failure [INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES] ---- 已存在签名,但使用证书不对,可以尝试使用其他证书签名。 签名方法:到目录android\build\target\product\security找到证书文件,这里可能会有几种证书,test/shared/platform/media,各种证书使用场景不同,可以自己google一下,因为签名很快而且可任意后续更改签名,可以自己尝试各种不同签名; 这个命令行是使用test证书的例子:java -jar signapk.jar testkey.x509.pem testkey.pk8 YOURAPK.apk YOURAPK_signed.apk YOURAPK_signed.apk就是签完名的apk,去测试一下您打包的apk吧。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值