irpas技术客

apk反编译教程(2022win11亲测)_诞总好_apk反编译

未知 1305

捣鼓apk反编译,想做一些羞羞的事情,网上的教程大多都比较旧,这里更新一篇比较新且详细的反编译教程。

目录

软件准备

apktool安装和使用

dex2jar安装和使用

jd-gui使用


软件准备

首先我们想要比较完整的解析一个apk需要三个工具:

????apktool (用于资源文件获取)????dex2jar (用于获取源码)????jd-gui (用于源码查看)

附上链接

apktool官网????????????????????????????????????https://ibotpeaches.github.io/Apktool/

dex2jar官方github仓库???????????????????https://github.com/pxb1988/dex2jar

jd-gui Google Code仓库(直接下载)?????????????????https://storage.googleapis.com/google-code-archive-downloads/v2/code.google.com/innlab/jd-gui-0.3.3.windows.zip

这里jd-gui其实是比较次要的,因为大多数情况到不了看代码这一步,dex2jar就解析不了了


apktool安装和使用

apktool官网讲解安装方法非常详细---->>https://ibotpeaches.github.io/Apktool/install/

这里再翻译啰嗦一下

首先先检查java环境,然后把下面这一段放在文本文档里面改个后缀改成 apktool.bat

@echo off setlocal set BASENAME=apktool_ chcp 65001 2>nul >nul set java_exe=java.exe if defined JAVA_HOME ( set java_exe="%JAVA_HOME%\bin\java.exe" ) rem Find the highest version .jar available in the same directory as the script setlocal EnableDelayedExpansion pushd "%~dp0" if exist apktool.jar ( ? ?set BASENAME=apktool ? ?goto skipversioned ) set max=0 for /f "tokens=1* delims=-_.0" %%A in ('dir /b /a-d %BASENAME%*.jar') do if %%~B gtr !max! set max=%%~nB :skipversioned popd setlocal DisableDelayedExpansion rem Find out if the commandline is a parameterless .jar or directory, for fast unpack/repack if "%~1"=="" goto load if not "%~2"=="" goto load set ATTR=%~a1 if "%ATTR:~0,1%"=="d" ( ? ?rem Directory, rebuild ? ?set fastCommand=b ) if "%ATTR:~0,1%"=="-" if "%~x1"==".apk" ( ? ?rem APK file, unpack ? ?set fastCommand=d ) :load %java_exe% -jar -Duser.language=en -Dfile.encoding=UTF8 "%~dp0%BASENAME%%max%.jar" %fastCommand% %* rem Pause when ran non interactively for /f "tokens=2" %%# in ("%cmdcmdline%") do if /i "%%#" equ "/c" pause

然后下载官网最新的??apktool.jar??,我这里目前是2.6.0之后改名成???apktool.jar

两个文件(apktool.bat和jar)放在同一个文件夹下面,然后把要反编译的apk也放进来,之后用cmd在该文件夹下面执行命令???apktool.bat d -f ?test.apk ?test???更改你自己的apk名称和输出文件夹打开“test”文件夹,就可以看到反编译后生成的文件,在这些生成的文件和文件夹当中,我们关心的是res文件夹中和AndroidManifest.xml文件,打开res文件夹,里面存放了我们所关心的xml文件,如下图所示:

???

dex2jar安装和使用

dex2jar官方github仓库里面进入下载最新版的SNAPSHOT如下图

???

?

解压之后,把apk文件的后缀改成zip再解压获取classes文件,类似下图

把要反编译的classes文件放在SNAPSHOT文件夹里面执行命令

d2j-dex2jar.bat???classes.dex

?这里测试了两个

错误示范:如果下载了错误的(低的)版本可能会报错

error warning

有些离谱的解决方案是修改dex文件里面的037为036或者035

离谱操作

但是我试了是不行

jd-gui使用

????最后我们用jd-gui打开反编译出来的jar文件

END?


1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,会注明原创字样,如未注明都非原创,如有侵权请联系删除!;3.作者投稿可能会经我们编辑修改或补充;4.本站不提供任何储存功能只提供收集或者投稿人的网盘链接。

标签: #apk反编译