编译Xposed

Xposed是Android平台上的有名的Hook工具,用它可以修改函数参数,函数返回值和类字段值等等,也可以用它来进行调试。Xposed有几个部分组成:

  • 修改过的android_art,这个项目修改部分art代码,使Hook成为可能
  • Xposed native部分,该部分主要提供给XposedBridge可调用api和调用修改过的android_art的api,还有生成可替换的app_process程序
  • XposedBridge,该项目是主要功能是提供给Xposed的模块开发者api,它将编译成XposedBridge.jar
  • XposedInstaller,该项目是Xposed安装器,使得普通用户在使用Xposed更方便,同时,它还可以管理手机上已经安装的Xposed模块,它编译完成后将生成apk文件,本文不讨论如何编译它。
    了解了这些,下面我们来试试如何编译它们

    准备

  • Ubuntu系统,推荐16.04及以上,本文用的18.04
  • Android Studio
  • Android源码(下载链接,请百度)
  • 修改过的android_art:https://github.com/rovo89/android_art
  • Xposed native部分:https://github.com/rovo89/Xposed
  • XposedBridge:https://github.com/rovo89/XposedBridge
  • Xposed构建工具,XposedTools:https://github.com/rovo89/XposedTools

配置

Android ART

将Android源码下的art目录移动到其他路径备份,比如Android源码的上层路径。在Android源码目录执行git clone https://github.com/rovo89/android_art -b xposed-nougat-mr2 art,将修改过的android art下载到Android源码根目录。

注:请注意上面选择的分支是xposed-nougat-mr2,我使用的是 Android7.1.2的源码,所以选择该分支。请根据Android源码版本选择分支。

Xposed Native

转到frameworks/base/cmds目录,执行git clone https://github.com/rovo89/Xposed xposed,将Xposed Native部分的源码下载。

XposedBridge

在任意目录执行git clone https://github.com/rovo89/XposedBridge,然后导入Android Studio中,点Build->Rebuild Project,会在app/build/intermediates/transformpreDex/release目录下生成.jar文件,将生成的jar文件重命名为XposedBridge.jar,放入Android源码目录下的out/java/

注:如果想生成供Xposed模块调用的XposedBridge.jar,则在Android Studio的右侧打开Gradle Project,双击jarStubs就会在app/build/api生成api.jar

XposedTools

在任意目录执行git clone https://github.com/rovo89/XposedTools,将XposedTools目录下的build.conf.sample复制一份,并将它重命名为build.conf,build.conf文件用于配置构建环境,我们来看他的内容:

[General]
outdir = /android/out
javadir = /android/XposedBridge

[Build]
# Please keep the base version number and add your custom suffix
version = 65 (custom build by xyz / %s)
# makeflags = -j4

[GPG]
sign = release
user = 852109AA!

# Root directories of the AOSP source tree per SDK version
[AospDir]
19 = /android/aosp/440
21 = /android/aosp/500

# SDKs to be used for compiling BusyBox
# Needs https://github.com/rovo89/android_external_busybox
[BusyBox]
arm = 21
x86 = 21
armv5 = 17
  • outdir:指定Android源码中的out目录
  • javadir:指定XposedBridge目录,如果你不需要编译XposedBridge.jar可以不指定
  • version:Xposed版本,这个版本号将显示在XposedInstaller上
  • ApospDir下的数字:设置sdk版本对应的Android源码
  • [BusyBox]标签:busybox,可以不指定

配置完成后,就可以执行build.pl编译了,以下有几个例子:

./build.pl -a java
编译XposedBridge.jar,需要在build.conf里指定javadir

./build.pl -t arm:25
编译生成供cpu架构为arm,sdk为25平台使用的Xposed

编译完成后,将在Android源码目录/out/sdk25/arm生成可刷入手机的zip文件

常见问题

1.执行build.pl的时候提示找不到函数,比如提示找不到Config::IniFiles.

可以通过下面的方式来寻找并安装依赖:
(1)执行apt-cache search Config::IniFiles寻找Config::IniFiles所依赖的库文件:

libconfig-inifiles-perl - Read .ini-style configuration files

(2)执行sudo apt install libconfig-inifiles-perl安装所依赖的库

posted @ 2018-09-13 11:11  koflfy  阅读(398)  评论(0编辑  收藏  举报