网上关于apk的反编译文章已经很多了,在这里再炒炒冷饭,写一个关于反编译的小功能,算是周末练练手,主要的功能描述起来很是简单,就是右键一个apk文件,点一下右键菜单栏里面的某个选项,然后就会在当前目录下生成这个apk反编译之后的文件夹了。
制作思路很简单,分两部走:
- 编写install和uninstall批处理,将该项功能添加到右键菜单栏里
- 编写主要功能的批处理,其实就是调用apktool和dex2jar这两个现成的东西
效果如下图,随便下个apk然后执行一下:
打开生成的文件夹,里面的文件大家应该都很熟悉,res下面就是资源文件,classes_dex2jar.jar则是反编译之后的代码,可以用jd-gui.exe这个工具来打开。在本文后面会附上这个小工具的下载链接,接下来也就基本都是在贴代码了。
install和uninstall批处理的实现
这两个其实也是很简单的,主要就是用dos命令里面的REG ADD,具体参数什么的,可以通过dos的帮助命令查看,比如REG ADD /?可以看到具体有关ADD的参数介绍,如下图
所以install的批处理也就是运用reg add来实现的一个简单功能,具体就看下面的代码:
@echo off
set recode=android_recode.bat
set command=%cd%\%recode%
echo %command%
REG ADD "HKEY_CLASSES_ROOT\*\shell\Apk decompile" -f
REG ADD "HKEY_CLASSES_ROOT\*\shell\Apk decompile\command" /d %command%" """%%1"" -f
pause
看到上面的Apk decompile就知道,这就是右击文件时,菜单栏里显示的内容,如果想换成其文字描述的只要替换这个字符串即可。
那么uninstall也就更简单了,跟install同理,都是调用reg的方法,想知道reg下面有那些方法,可以通过reg /?来查看。接下来贴uninstall的代码
@echo off
REG DELETE HKEY_CLASSES_ROOT\*\shell\Apk" "decompile /f
pause
到此功能的安装和卸载都实现了,其实也就是简单的添加注册表和卸载注册表。下面是执行反编译功能的批处理。
主要实现的功能
@echo off
::下面是获取文件夹名字
set v=%~nx1
set s=
set t=.
:start
if not "%v%"=="" (
set tp=%v:~0,1%
if "%tp%" =="%t%" goto end
set s=%s%%v:~0,1%
set v=%v:~1%
goto start
)
:end
set d=%s:~0,-1%
set current=%cd%
::切换到/用户目录下,删除apktool文件夹,是为了以防冲突
cd /d "%USERPROFILE%"
rd apktool /q/s
::切换回当前目录
cd /d %current%
::echo "%~dp0\tools\apktool\apktool.bat"
::echo %cd%\%d%
call "%~dp0\tools\apktool\apktool.bat" d --no-src -f %1 %cd%\%d%
call "%~dp0\tools\dex2jar\dex2jar.bat" %cd%\%d%\classes.dex
echo 反编译完成,请打开本目录下的%d%文件夹
pause
二话不说先贴代码,还有,各位会发现上面代码里前面一大堆代码只是获取最后生成的文件夹名字,由于本人对dos命令不是很熟悉,这一段写的应该是会有点啰嗦,如果有更好的方法希望朋友们可以告之。
然后最主要的功能就是下面的两句,其实就是简单调用apktool和dex2jar提供的功能,然后输出到当前目录下。至此,一个简单的小功能就完成了。