Xposed源码编译踩坑实录

Posted imist

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Xposed源码编译踩坑实录相关的知识,希望对你有一定的参考价值。

参考博文

编译Xposed

  • 参 考博文 https://www.jianshu.com/p/c731cd44e82b
  • 参考博文 https://www.cnblogs.com/luoyesiqiu/p/9524651.html

    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源码版本选择分支或者对应的标签,或者git checkout xposed-marshmallow 直接切换到对应的远程分支
  • Xposed Native
    • 转到frameworks/base/cmds目录,执行git clone https://github.com/rovo89/Xposed xposed,将Xposed Native部分的源码下载
  • XposedBridge
    • 在任意目录执行git clone https://github.com/rovo89/XposedBridge -b art,然后导入Android Studio中,点Build->Rebuild Project,会在app/build/intermediates/transform/preDex/release目录下生成.jar文件,将生成的jar文件重命名为XposedBridge.jar,放入Android源码目录下的out/java/下。也可以直接生成apk,然后将生成的apk后缀改为jar
    • 将生成的jar导入aosp/out/target/product/hammerhead/system/framework/

这里jar文件存放的目录不同的博文是不一致的,但是觉得framework里面靠谱一点

注:如果想生成供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]
# 如果不编译XposedBridge,需要自行将XposedBridge.jar放置到输出目录的 java文件夹下
outdir = /home/misty/bin/WORKING_DIRECTORY/out
#javadir = /android/XposedBridge

[Build]
# Please keep the base version number and add your custom suffix
version = 86 (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
23 = /home/misty/bin/WORKING_DIRECTORY
                                                             
# SDKs to be used for compiling BusyBox
# Needs https://github.com/rovo89/android_external_busybox

#[BusyBox]
#arm = 23
#x86 = 23
#armv5 = 23



* 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 arm64:23

  • 编译生成供cpu架构为arm64,sdk为23平台使用的Xposed

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

配置 perl 环境

  • XposedTools 依赖于 perl,所以我们要跑起来就要有一个 perl 环境。首次运行 perl 需要安装依赖 Config::IniFiles
    perl -MCPAN -e ‘install Config::IniFiles‘

  • 大概需要在安装下面的两个依赖(不同系统可能不同)
    perl -MCPAN -e ‘install File::Tail‘
    perl -MCPAN -e ‘install File::ReadBackwards‘

  • 如果还不成功,按照下面的方法安装所需的模块即可
    perl -MCPAN -e ‘install [ModuleName]‘

解决模块安装失败的问题

  • 执行build.pl的时候提示找不到函数,比如提示找不到Config::IniFiles. 可以通过下面的方式来寻找并安装依赖:
    • 执行apt-cache search Config::IniFiles寻找Config::IniFiles所依赖的库文件
    • 执行sudo apt install libconfig-inifiles-perl安装所依赖的库
      libconfig-inifiles-perl - Read .ini-style configuration files
  • 使用aptitude工具下载依赖
    • sudo aptitude install Config::IniFiles
    • sudo aptitude install File::Tail
    • sudo aptitude install File::ReadBackwards

      虽然可能会出现安装失败,但是会出现依赖提醒,按照提示安装依赖即可

根据提示安装依赖cpan -f Archive::Zip

Can't locate Archive/Zip.pm in @INC (you may need to install the Archive::Zip module) (@INC contains: /home/aosp/xposed/XposedTools /etc/perl /usr/local/lib/perl/5.18.2 /usr/local/share/perl/5.18.2 /usr/lib/perl5 /usr/share/perl5 /usr/lib/perl/5.18 /usr/share/perl/5.18 /usr/local/lib/site_perl .) at ./build.pl line 11.
BEGIN failed--compilation aborted at ./build.pl line 11.

root@a03e3a9cc004:/home/aosp/xposed/XposedTools# cpan -f Archive::Zip

常见问题

  • art更名替换导致如下错误,不可以在源码根目录下,需要移动到其他目录,本例移动到上级目录
    build/core/base_rules.mk:157: *** art_bak: MODULE.TARGET.FAKE.cpplint-art-phony already defined by art。 停止。

       #### make failed to build some targets (6 seconds) ####

编译XposedBridge问题

编译android6.0源码需要java1.7,而编译xposedbridge需要java1.8,所以这里为了切换方便临时指定java环境变量

misty@ubuntu:~/bin/xposed/XposedTools$ ./build.pl -a java 
Loading config file /home/misty/bin/xposed/XposedTools/build.conf...
Checking requirements...
Building the Java part...
Compiling...

FAILURE: Build failed with an exception.

  • Where:
    Build file ‘/home/misty/bin/xposed/XposedBridge/app/build.gradle‘ line: 3

  • What went wrong:
    A problem occurred evaluating project ‘:app‘.

    java.lang.UnsupportedClassVersionError: com/android/build/gradle/AppPlugin : Unsupported major.minor version 52.0

  • Try:
    Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.

BUILD FAILED

Total time: 0.682 secs

misty@ubuntu:~/bin/xposed/XposedTools$ vim /etc/profile
misty@ubuntu:~/bin/xposed/XposedTools$ export JAVA_HOME=/home/misty/MyFile/jdk1.8.0_211
misty@ubuntu:~/bin/xposed/XposedTools$ export PATH=$PATH:$JAVA_HOME/bin
misty@ubuntu:~/bin/xposed/XposedTools$ java -version

相关命令

getprop|grep arm 查看CPU相关的信息

小确幸

每一丝灵感都值得被记录,每一笔记录都是成长,每一点成长都值得欢呼

博主个人站: www.imisty.cn
CSDN博客: https://blog.csdn.net/lookinthefog
博客园 :https://imist.cnblogs.com/

希望能够认识一些热爱技术的小伙伴,欢迎友链接哟

以上是关于Xposed源码编译踩坑实录的主要内容,如果未能解决你的问题,请参考以下文章

LAMP源码编译安装实录

LNMP源码编译安装实录

Chromium内核浏览器编译记踩坑实录

Chromium内核浏览器编译记踩坑实录

kibana 5.5 源码编译踩坑记录

物联网-thingsboard源码编译安装踩坑记录