Xposed插件开发入门

Xposed的用处不必言说,能hook任意java写的代码,修改替换apk内部的资源文件。
至于如何开发一个XPosed的插件,官方给出的答案如下:
https://github.com/rovo89/XposedBridge/wiki/Development-tutorial
看完这篇文章,基本能写出一个最简单的demo。


现在先讲讲这个最简单的demo怎么写

1.先新建一个android project(推荐用android studio)
这个project不需要任何activity,相关的组件引用也可以删光,这样编译后的apk就很小了。

2.修改项目的build.gradle
追加2个配置

repositories {
jcenter();
}

dependencies {
provided 'de.robv.android.xposed:api:82'
}

3.修改AndroidManifest.xml 让xposed能识别这个插件
正常情况下,xposed是无法识别我们的应用是不是xposed插件的,我们必须在manifest上打上一个标签来声明自己。
官方给的例子如下

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="de.robv.android.xposed.mods.tutorial"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <meta-data
            android:name="xposedmodule"
            android:value="true" />
        <meta-data
            android:name="xposeddescription"
            android:value="Easy example which makes the status bar clock red and adds a smiley" />
        <meta-data
            android:name="xposedminversion"
            android:value="53" />
    </application>
</manifest>

简单的讲,就是application配置段内添加如下3个属性就好了

     <meta-data
            android:name="xposedmodule"
            android:value="true" />
        <meta-data
            android:name="xposeddescription"
            android:value="Easy example which makes the status bar clock red and adds a smiley" />
        <meta-data
            android:name="xposedminversion"
            android:value="53" />

4.实现xposed的接口
空白的class如下

package cn.coderstory.xposeddemo;
public class Demo  {

}

如果我们想要这个类有hook各种代码的能力,我们需要让这个类实现一些xposed框架提供的接口。
具体实现什么接口,需要看我们具体的需求。

 

常见的额接口如下
IXposedHookZygoteInit, IXposedHookLoadPackage, IXposedHookInitPackageResources
IXposedHookZygoteInit接口实现了ZygoteInit阶段的hook能力,用于在Zygote进程启动之前执行相关代码,framework里的东西一般再这里改。
IXposedHookLoadPackage接口实现了加载app阶段的hook能力,用于hook app的代码
IXposedHookInitPackageResources接口实现了加载app资源时的hook能力,用于修改app的一些资源,比如布局文件什么的。

 

 

 

5.写具体的代码逻辑

现在我们写一个功能,比如隐藏MIUI下拉菜单里面的搜索框

参考源码:点我

 

package cn.coderstory.xposeddemo;

import de.robv.android.xposed.IXposedHookInitPackageResources;
import de.robv.android.xposed.callbacks.XC_InitPackageResources;

/**
 * Created by cc on 2017/1/3.
 * 隐藏MIUI下拉菜单搜索框
 */
//IXposedHookInitPackageResources接口实现修改资源app的资源文件
public class Demo implements IXposedHookInitPackageResources{

 @Override
 public void handleInitPackageResources(XC_InitPackageResources.InitPackageResourcesParam resparam) {
   //如果当前处理的是systemui
   if (resparam.packageName.equals("com.android.systemui")) {
     //调用setReplacement方法替换名为config_show_statusbar_search的变量值为false
     resparam.res.setReplacement(resparam.packageName, "bool", "config_show_statusbar_search", false);
   }
 }
}

这样,功能就写好了。

6.创建和编辑xposed_init配置文件

接下来我们需要再项目里新建一个名为assets的目录,然后在目录里新建一个名为xposed_init的文件,文本类型的。
这个文件主要记录了app里所有实现xposed功能的类,在开机的时候,xposed会依次加载这些类。

 

新建assets目录

 

新建xposed_init文件,类型选择Text

 

xposed_init里写当前类的路径 如果存在多个类,那么每行写一个,多个写多行

 

 

7.编译安装

编译的时候需要关闭android studio的instant run 功能。

手机上安装后 需要在xposed install上勾选启用模块并重启。

 

成品apk:
https://blog.coderstory.cn/wp-content/uploads/2017/01/app-debug.zip

源码:
https://blog.coderstory.cn/wp-content/uploads/2017/01/XposedDemo.zip

 

点赞
  1. c说道:
    Google Chrome Windows 10

    膜拜大神,最近在看xposed开发的东西,请问有没交流群之类的?

    1. coderstory说道:
      Google Chrome Windows 10

      没有。。

  2. kenea说道:
    Internet Explorer Windows 10

    @coderstory 能否把MIUI主题和谐模块在Magisk里作开发?现在XPOSED框架没有更新7.0+

    1. coderstory说道:
      Google Chrome Windows 10

      这是2个层面的东西 又不互通的

  3. wjh说道:

    小弟求教-红包插件的实现·····秋秋19515024

    1. coderstory说道:

      你不觉得这有点过分么 自己反编译别人家的红包插件 自己看实现吧

    2. c说道:
      Google Chrome Windows 10

      github上有开源项目,不root不要xposed。监听通知就能实现,去找找看吧。

  4. 说道:

    小米净化框架插件激活不了,重启还是不行,最新版本

    1. coderstory说道:

      卸载小米净化 重启手机 再次安装

      1. 123说道:

        小米净化激活后,手机连接电脑不显示那个手机内存的磁盘了,关闭小米净化就好了 ,这是个BUG,还是我设置的不对?

发表评论

电子邮件地址不会被公开。必填项已用 * 标注