Android 集成Xposed框架

前言

Xposed(框架)

Xposed框架(Xposed Framework)是一套开源的、在Android高权限模式下运行的系统框架服务,可以在不修改APK文件的情况下影响程序运行(修改系统)的框架服务,基于它可以制作出许多功能强大的模块或插件。

XopsedInstall

是管理和安装Xposed框架及Xposed模块或者插件的应用工具(apk);

注意:要区分Xposed和XposedInstall的概念;

Xposed及XposedInstall

https://github.com/rovo89

XposedInstall下载

https://repo.xposed.info/module/de.robv.android.xposed.installer

https://dl-xda.xposed.info/modules/de.robv.android.xposed.installer_v33_36570c.apk

Xposed的jar包

https://bintray.com/rovo89/de.robv.android.xposed/api

Xposed运行环境

手机必须ROOT,这也是Xposed的比较遗憾的地方;我使用的是逍遥模拟器,这样就解决了没有root手机的问题;

 

应用场景

可以通过集成了Xposed框架的App(模块或者说插件)来Hook其他APP,Hook能够将自己的代码“融入”被勾住(Hook)的进程中,成为目标进程的一部分;在Andorid沙箱机制下,Hook是我们能通过一个程序改变其他程序某些行为得以实现;

新建一个被Hook的APP

1,为了简单明了此APP只有一个主页面,里面有一个TextView显示Hook前后的不同;

此APP包名:com.ang.target

public class MainActivity extends AppCompatActivity {
    private TextView tv_hello;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv_hello = findViewById(R.id.tv_hello);
    }
}

layout布局文件:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">


    <TextView
        android:id="@+id/tv_hello"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="hello world"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />



</androidx.constraintlayout.widget.ConstraintLayout>

2,把被hook的应用安装到已经ROOT的手机或者Root的模拟器中;

 

集成Xposed框架的APP

项目地址:https://github.com/lz-ang/XposedSample.git

1,AndroidStudio新建项目,项目名称:XposedSample,此项目可以有Activity也可以没有;

如果没有Activity需要通过命令打包成APK,Terminal终端运行 gradlew app:assembleDebug命令打包apk

2,model下的build.gradle引入依赖,也可以不引入依赖,引入jar包的方式;需要注意都是在编译有效,打包的时候都不打包进去(compileOnly或者compileOnly fileTree);

compileOnly 'de.robv.android.xposed:api:82'
compileOnly 'de.robv.android.xposed:api:82:sources'

3,AndroidManifest.xml中配置

在Application标签里面(和Activity同级)加三个meta-data

<!-- 是否是xposed模块,xposed根据这个来判断是否是模块 -->
<meta-data android:name="xposedmodule" android:value="true" /> 

<!-- 模块描述,显示在xposed模块列表那里第二行 -->
<meta-data android:name="xposeddescription" android:value="测试Xposed模块" />

<!-- 最低xposed版本号(lib文件名可知) --> 
<meta-data android:name="xposedminversion" android:value="30" />

4,新建Hook工具类,类名自定义即可;并实现IXposedHookLoadPackage接口;

public class HookUitl implements IXposedHookLoadPackage {

    @Override
    public void handleLoadPackage(XC_LoadPackage.LoadPackageParam lpparam) throws Throwable     {
    XposedBridge.log("Hook已经成功了");
    if (!lpparam.packageName.equals("com.ang.target")) {
        return;
    }

    if (lpparam.packageName.equals("com.ang.target")) {
        XposedHelpers.findAndHookMethod("com.ang.target.MainActivity",
            lpparam.classLoader, "onCreate", Bundle.class, new XC_MethodHook() {
            @Override
            protected void afterHookedMethod(MethodHookParam param) throws Throwable {

                //不能通过Class.forName()来获取Class ,在跨应用时会失效
                Class c = lpparam.classLoader.loadClass("com.ang.target.MainActivity");
                Field field = c.getDeclaredField("tv_hello");
                field.setAccessible(true);
                //param.thisObject 为执行该方法的对象,在这里指MainActivity
                TextView textView = (TextView) field.get(param.thisObject);
                textView.setText("Hello Xposed");
            }
        });
    }
    }
}

5,新建assets目录,并在此目录下新建文件名为:xposed_init 的文件,如果提示选择文件格式那就选text格式即可;

xposed_init 文件中写里面的代码是你的Hook类的包名+类名。

com.ang.xposedsample.HookUitl

6,安装到Root的手机或者模拟器中

 

安装XposedInstall

1,安装XposedInstall

2,在XposedInstall中安装Xposed框架,目前最新版本89,点击Version 89,根据提示安装;如上图"安装/更新",安装成功后重启手机;安装成功之后的界面如下;

3,XposedInstall在模块中找到XposedSample模块,并勾选;重启系统;然后点击XposedSample运行起来(我的是有主Activity),点击被Hook的应用;你会发现TextView的内容被改变了;说明Hook成功了;

 

如果连不上模拟器,执行如下命令

adb connect 127.0.0.1:21503

 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ang_qq_252390816

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值