Android基于LLVM的Native层代码混淆

1.采用LLVM进行Native层代码混淆,先看一下混淆的效果

混淆之前的函数:

Android基于LLVM的Native层代码混淆_第1张图片

混淆之后的函数:

Android基于LLVM的Native层代码混淆_第2张图片

混淆后的函数体几乎变得无法阅读!

2.再看文件大小变化:

混淆前:

Android基于LLVM的Native层代码混淆_第3张图片

混淆后:

Android基于LLVM的Native层代码混淆_第4张图片

 

3.如何集成:

首先下载源码并编译,参考:https://github.com/obfuscator-llvm/obfuscator/wiki/Installation

下面是实际用到的命令:

$ git clone -b llvm-4.0 https://github.com/obfuscator-llvm/obfuscator.git
$ mkdir build
$ cd build
$ cmake -DCMAKE_BUILD_TYPE=Release -DLLVM_INCLUDE_TESTS=OFF ../obfuscator/
$ make -j4

 

4.上面编译完成后,将build目录下的所有文件复制到ndk的toolchains/llvm/prebuilt/linux-x86_64目录中

编译后的build目录:

Android基于LLVM的Native层代码混淆_第5张图片

全部复制到toolchains/llvm/prebuilt/linux-x86_64目录下(有相同文件则覆盖):

Android基于LLVM的Native层代码混淆_第6张图片

 

5.在Android.mk中配置混淆选项

Android基于LLVM的Native层代码混淆_第7张图片

也就是加入下面这段:

LOCAL_CFLAGS += -mllvm -sub  -mllvm -bcf -mllvm -fla

各个选项说明文档:https://github.com/obfuscator-llvm/obfuscator/wiki/Features

     中文版:   https://www.cnblogs.com/20143605--pcx/p/10314863.html

 

6.操作完成,编译项目工程即可。

 

 

 

 

 

 

你可能感兴趣的:(Android,Android,NDK,Android逆向)