日期:2022-10-29 14:40:33
来源:互联网
点击:23
下面就是为您整理了的能反编译app的安卓软件的答案
什么反编译软件最好用?apk和exe的急需求解!。。。反编译也就是反向编译,是指通过对目标程序(可执行程序)进行逆向分析、研究工作,以推导出他人的软件产品所使用的思路、原理、结构、算法、处理过程、运行方法等设计要素,不一定能推导出源代码。
举个例子:
fla文件是动画的源代码文件,发...
哪个app反编译软件简单好用急需答案apktool、Smali2Java、dex2jar、jd-gui.这几个联合起来使用,一般没有混淆加密的,基本都可以反编译出来,不过反编译一般只限学习使用,不可乱用哦!!
如何反编译Android 的apk/dex/odex,获得源码有什么好的建议?反编译普通的APK文件:
对于普通的APK/DEX文件的反编译,其实工具有很多,
包括:
ByteCode
Viewer: 一个可视化的集成工具,说实话,不太好用,不够稳定,生成代码质量中等。dex2jar
jd_gui: 这两个工具组合还可以, 用起来比ByteCode Viewer麻烦一些,但比较稳定,生成代码质量中等。
反编译ODEX文件:
Android
5.0 Lollipop以后,Google用ART代替了以前的Dalvik,对于普通的app来说我们仍然可以用上面的方法来把dex文件反编译成Java源代码。但对于系统预装的App,特别是类似应用商店,播放器等, 你会发现这些应用的apk文件中找不到对应的classes.dex文件,而是会发现在其子目录下有个.odex文件。 那如何反编译这个odex文件呢?我通过google查了查,知道应该用baksmali,但从github上下载了几个版本都不行,报各种不同错误。
具体方法如下:
1. 从 这里 下载工具包, 解压缩到本地。 这里的baksmali的版本是32313133353236313431303231363533e58685e5aeb9313333613138392.0.3. 不同版本的baksmali针对的Android内核不同。有时候高版本反倒不好用。
2. 打开工具所在目录, 按住shift键, 点击鼠标右键,打开Windows命令窗口3. 把 odex文件拷贝到该目录4.
在命令窗口运行:
oat2dex.bat *.odex . 正常情况下,应该显示OK等信息。如果报错的话,说明这个文件无法转换,后面的也不用试了。
5. 运行 oat2dex.bat *.odex temp.dex . 运行后会创建一个temp.dex文件。
6. 运行 java -jar baksmali-2.0.3.jar -a 21 -x temp.dex -o source . 运行后会创建一个source的文件夹,并将temp.dex反编译到该文件夹。-a 21 表明的是Android内核的版本217. 运行 java -jar small-2.0.3.jar -a 21 source -o classes.dex , 反编译为classes.dex文件。
需要注意的是:
由这种方式反编译成的classes.dex 文件相比原生的classes.dex 还是缺少了些信息,因此反编译这种classes.dex 文件后生成的java代码可读性会更差些。
8. 用在线工具JADX 来把 classes.dex 最终反编译为java代码。
安卓app360加固怎么反编译有了解的吗?1 对比上传demo进行加固,解包后对比下原包和加固包,发现加固包在assets文件夹下多了libjiagu.so,libjiagu_x86,lib文件夹下多了libjiagu_art.so,同时修改了dex文件和AndroidManifest文件打开manifest文件,看到xxx加固对Application标签做了修改,添加了壳入口,也就是我们反编译后看到的StubApplication.smali这个文件。相比于之前版本的加固,自从1.x.x.x加固版本之后,多了几次反调试,使得动态难度稍微增大了一些,不过针对脱壳机脱壳,再多了反调试也是无用。或者通过修改系统源码,也能达到消除反调试的作用。2 动态调试(1)把app安装到手机,以调试模式打开app(2)以shell模式root权限打开IDA的android_server监听(3)tcp转发(4)打开IDA,修改配置为在进程开始时下断(5)搜索到进程后jdwp转发,pid值即为我们进程号,并在命令行下附加。成功附加后,可以下段了,打开Debugger Option我们选择在线程开始和库加载时下断,修改成功后,jdb附加,点击运行程序会断在elf头处,按下G键,搜索mmap,在mmap函数的段首和断尾下段F9运行,来到断尾时F8单步,来到此处时,在 BLunk_5C999C2C下断,F9一下,F7跟进去跟进去今后在BLX LR处进行下断,此处就是进行反调试的地方,原理依然是获取TracePid的值判断当前是不是处于调试状态,建议第一次调试的人在fgets和fopen处下断,再f7跟进此调用就可以看到TracePid的值了。跟进去之后,我们直接把方法移到最下方,就可以看到kill符号了,这就是杀进程的地方,如果当前处于调试状态,则直接结束进程。我们在此函数的所有cmpR0,#0处下断,F9一下后即断在断点处,观察寄存器窗口的R0值,实质就是当前的TracePid的16进制的值不确定的可以使用cat /proc/pid/status进行对比一下,我们直接把R0置0,右键选择Zero Value即可清0,继续F9我们看到程序又来到了mmap处,继续f9当继续断在调用反调试功能的方法时,继续F7跟进,依然在所有的cmp R0,#0处下断,断下后把R0清0后继续F9运行目前的规律是,调用BLXLR的第一次,
第二次和第四次是进行反调试判断的,
第三次并不影响,可以直接f9跳过去,三次反调试搞定后,就可以愉快的F9运行并观察堆栈窗口了当看到出现如下所示时:说明壳已经开始解密并释放dex文件了,我们直接F8单步十几步。
最后F9一下就可以看到我们需要的dex头了直接脚本mp出来即可。
最后把libjiagu的所有文件删除,并修复下Application标,如果存在则修复,不存在删除即可
资料能反编译app的安卓软件来源于网友整理,仅供参考。安卓应用的优势包括:
提示:想了解更多能反编译app的安卓软件(能反编译app的安卓软件)相关的内容,请尝试通过上方搜索框搜索。