美文网首页
android 未混淆反编译

android 未混淆反编译

作者: CreScert | 来源:发表于2020-05-08 18:16 被阅读0次

参考网址:
https://blog.csdn.net/qq_33721320/article/details/94553756
https://www.cnblogs.com/f839903061/archive/2012/11/26/2788819.html
https://blog.csdn.net/qq_32452623/article/details/54291412

故事的起因是因为我一个未提交的布局A,由于要新画界面B,没有拷贝A直接更改了布局文件A,反应过来的时候布局A已经撤回不去了。。。。但是界面懒得再画一遍了。就想到了之前运行的包(因为 每次运行项目时都会在app/build/bakApk/目录下保存一份debug包),这时候只要拿到包就可以了,吗?

当打开后发现布局文件全是乱码...

在寻找的过程中顺便学了下反编译..

先说简单的,反编译清单文件(以下都是未混淆的代码前提下反编译,混淆过的下面方法没有用~~~~~)

说之前,先把需要的工具都说明下,由于有的工具下载比较困难,所以我提交到github上面,需要的盆友可以下载下来自行保存:https://github.com/CreScert/androidtool

image.png

1.反编译清单文件
需要的工具是:AXMLPrinter2.jar,也就是 pconline1482113373043.zip
下载下来后,把需要反编译的清单文件和AXMLPrinter2.jar放在同一个目录,打开命令行进到此目录,输入

java -jar AXMLPrinter2.jar AndroidManifest.xml 
image.png

反编译清单文件就完成了。

下面是反编译下Apk类

2.反编译Apk类
需要的工具是:dex2jar(dex2jar-2.0.zip) 和 JD-GUI(jdguiwindows.zip)

备注:前者是将apk中的classes.dex转化成Jar文件,而JD-GUI是一个反编译工具,可以直接查看Jar包的源代码。

使用
1.首先将apk文件,将后缀改为zip,解压,得到其中的classes.dex,它就是java文件编译再通过dx工具打包而成的;
2.解压下载的dex2jar,将classes.dex(最好将classes1..2..3.都拿过来)复制到dex2jar.bat所在目录。在命令行下定位到dex2jar.bat所在目录
3.输入:

dex2jar.bat classes.dex 

如果没有dex2jar.bat,使用d2j-dex2jar.bat就行:

d2j-dex2jar.bat classes.dex 

生成 classes.dex.dex2jar.jar

image.png

运行JD-GUI(jd-gui.exe),打开上面生成的jar包,即可看到源代码了。

下面是反编译下布局文件:

3.反编译布局文件

需要工具:aapt.exe,apktool.bat,apktool.jar
其中:aapt.exe在android sdk\build-tools\里面随便一个版本的aapt即可。

apktool在貌似2之前的和2之后的不一样,如果是2之后的就用下面的方法,之前的我没处理过~

apktool.bat的内容如下:

@echo off
if "%PATH_BASE%" == "" set PATH_BASE=%PATH%
set PATH=%CD%;%PATH_BASE%;
chcp 65001 2>nul >nul
java -jar -Duser.language=en -Dfile.encoding=UTF8 "%~dp0\apktool.jar" %*

apktool.jar这个因为翻墙不好下载的去网上下载即可,记得下载2版本以后的。下载好后记得更改文件名为apktool.jar

最后是这三个:


image.png

网上说最好放在C盘,我们就放在C盘,将apk放在C盘的根目录(哪里都行,输对就行)

apktool d -f c:\app.apk -o c:\app_output\

注意这里的语法,网上有好多是 apktool d c:\app.apk c:\app_output\,这样会报错:
Input file (c:\app_output) was not found or was not readable.

image.png

解决办法:是因为apktool升级到2.0以上时,使用方式已经替换,格式为:apktool d [-s] -f <apkPath> -o <folderPath>,参数具体的意思可以直接打apktool回车(windows)查看帮助

说明:apktool d [-s] -f apk的位置 -o 最后生成的目录(这个是目录哦~)
-f 是强制覆盖已经存在的目录。

最后的结果是:


image.png

最后提示个小技巧:3步骤生成的布局文件中的android:id是@id/格式的,不是@+id/格式的。


image.png

可以用记事本的替换功能:
android:id="@id/ 替换为 android:id="@+id/

收工,有问题欢迎指出~

相关文章

  • android 未混淆反编译

    参考网址:https://blog.csdn.net/qq_33721320/article/details/94...

  • Android Apk 反编译与混淆

    Android Apk 反编译与混淆 反编译工具 目前反编译工具有四类 1、apktool 主要用于资源文件的获取...

  • Android的多渠道打包|SquirrelNote

    系列文章:Android的反编译和代码混淆Android的打包签名[Android的多渠道打包 前言 本篇包括以下...

  • Android的反编译和代码混淆

    系列文章:Android的反编译和代码混淆Android的打包签名Android的多渠道打包 前言 包括以下内容 ...

  • Android的打包签名

    系列文章:Android的反编译和代码混淆Android的打包签名Android的多渠道打包 前言 从以下几个方面...

  • Android开发安全手册

    常规安全防御手段 混淆 混淆是Android基本安全手段,虽然目前有很多工具能够反混淆,但是对于反编译调试代码还是...

  • 全面解析:Android开发中的Proguard混淆配置

    为什么要进行代码混淆?   混淆在我们实际的Android开发中是必不可少的,如果不混淆, 发布出去,别人一反编译...

  • Android 混淆总结

    混淆 关于混淆的概念请移步郭霖大神博客:Android安全攻防战,反编译与混淆技术完全解析(下)。小白必看,全面易...

  • Android如何进行混淆

    android开发为什么要进相混淆? Android开发使用Java作为开发语言,Java代码是非常容易反编译的。...

  • android之代码混淆

    项目发布之前混淆是必不可少的工作,混淆可以增加别人反编译阅读代码的难度,还可以缩小APK包。 Android 中通...

网友评论

      本文标题:android 未混淆反编译

      本文链接:https://www.haomeiwen.com/subject/jgxqnhtx.html