首页
论坛
专栏
课程

[原创]dex一键反编译smali/回编译自动拆分dex包工具

2019-7-27 00:56 1535

[原创]dex一键反编译smali/回编译自动拆分dex包工具

2019-7-27 00:56
1535
有个小技巧能阻止现在流行的反编译工具,诸如jeb2或者MT管理器对整体apk直接进行的反汇编工作,会导致反编译失败。那就是在app有多DEX的情况下,对每个DEX都添加少量的路径重复文件。

应对的思路也简单,把所有dex都反编译到同一目录下,这样重复的文件就会自动覆盖合并。随后回编译为dex会遇到一点小麻烦,直接用smali.jar进行回编译会出现方法数超过65535而导致失败问题。手动操作是不可能的了,于是楼主自己写了小工具。原理很简单实用就好,两个功能定位:一键将所有dex文件反编译到同一目录下,一键将合并的smali文件在达到DEX方法数限制之前进行拆分。

smali_decompile.py 自动遍历一个目录下的所有DEX,依次反汇编输出到指定目录,简单讲你需要解压一下APK文件。支持反编译到classes*.dex对应目录,或者全都反编译到一个classes目录下。
python  smali_decompile.py -d d:\apk_unziped -o  d:\apk_unziped -m one

$ python smali_decompile.py                                                     
Smali dex to smali_file.                                                        
-h Show this help                                                               
-d Directory to unziped apk                                                     
-o Output path                                                                  
-m [one|each] Decompile dex to single folder or each folder                     
eg. smali_decompile.py -d ~/test -o ~/test2 -m each                             


smali_split.py 自动将全部合并在一起的smali文件拆分到不超过65535方法数限制的classes*目录中,随后依次回编译DEX文件。

python smali_split.py -a d:\apk_unziped\classes -o d:\apk_unziped

$ python /e/Workspace/Python3/android/smali_tools/smali_split.py
Auto split a large number of smali files into dex files.
-h Show this help
-a Directory to all smali files.
-o Output path
eg. smali_split.py -a /test -o /test2


github地址
https://github.com/DXCyber409/py3util/tree/master/android/smali_tools

运行之前修改一下config.ini配置文件

[path]

java_home =  #Java路径,如果PATH变量中有JAVA_HOME不用填写也行

baksmali_tool = D:\Tools\Android\baksmali-2.2.5.jar

smali_tool = D:\Tools\Android\smali-2.2.5.jar



[公告]安全服务和外包项目请将项目需求发到看雪企服平台:https://qifu.kanxue.com

最后于 2019-7-27 22:32 被plzaq编辑 ,原因: 修正描述
最新回复 (3)
kllei 2019-7-27 15:47
2
0
感谢,python smali_decompile.py -a d:\apk_unziped\classes -o d:\apk_unziped,这里应该是python smali_split.py -a d:\apk_unziped\classes -o d:\apk_unziped,python版本也可以注明一下,里面有的写法和函数低版本不支持
plzaq 2019-7-27 18:11
3
0
kllei 感谢,python smali_decompile.py -a d:\apk_unziped\classes -o d:\apk_unziped,这里应该是python smali_split.py ...
感谢指出,一般区分python2和python3就行了。最简单的看print的写法,print空格是python2,print(括号)是python3。python2在2.7版本要停止更新了,以后可能都会统一python3+。
mb_imneizfd 2019-7-27 21:10
4
0
没有电脑安卓手机怎么操作请大佬指点
游客
登录 | 注册 方可回帖
返回