【xposed】- 基础篇(1)

作者: 拔萝卜占坑 | 来源:发表于2020-04-13 15:59 被阅读0次

    简介

    xposed框架出来已经有一段时间了,之前只是看别人的技术博客,说是很强大,但是自己并没有亲手去实践过。一方面据说xposed需要root过的手机,自己没有,最近把自己手机root,开始玩一玩xposed。当然没有root的手机也可以安装xposed。

    作用

    xposed可以给程序执行过程挂上勾子(hook),然后加入我们自己的处理逻辑。比如你想修改某应用程序中的变量,函数实现等等。

    场景

    需求开发完成,测试通过,打正式包,加固,上传应用市场。突然第二天,发现线上应用出现bug,而测试环境又不能浮现。如果用线上正式包,看不到日志,不能调试等等。

    当然你说,可以自己本地打一个可以调试,看日志的正式包,如果觉得不麻烦,当然可以(大一点的工程,编译,打包可以要一点时间的),但是应用如果是经过加固的,那还得加固,估计调试解决bug有点头疼。

    那这时候,就可以用xposed写个插件,将正式包的调试,日志开关打开,将崩溃的地方dialog提示,等等。这样不会在原工程添加任何代码或者修改,岂不是很方便。

    参考

    说明

    xposed插件开启,关闭,插件修改后都需要重新启动系统,才能生效。

    免重启

    当然网上有关于插件开发过程中,修改后免重启的解决办法,可自行百度。

    安装

    • 设备
      root手机一台
    • xposed卡刷包
      framework下载xposed卡刷包,注意下载时候要对于自己手机的系统版本和cpu型号,cpu型号查看方法自己百度。使用第三方Recovery刷入xposed卡刷包。
    • Xposed installer.apk
      xda-developers安装包安装到手机上。
    • 重启手机
    • 打开Xposed installer.apk
      如果出现下面界面,者安装成功。


      截屏2020-04-13下午3.19.27.png

    右上角可以打开或者关闭xposed,左上角菜单中的模块里面列举就是目前手机安装的xposed插件,可以在里面开启或者关闭,但都需要重启系统才能生效。

    开发

    开发xposed插件需要XposedBridge包,下载后,放入工程。

    • 新建工程
      Android Studio新建一个Android工程或者module
    • 编写hook类
      public class XposedHookTest implements IXposedHookLoadPackage {
          @Override
          public void handleLoadPackage(XC_LoadPackage.LoadPackageParam lpparam) throws Throwable {
            // todo
          }
      }
      
      当然不是只能实现IXposedHookLoadPackage,xposed具体用法自己百度。
    • 告诉xposed插件hook实现类
      在assets目录下新建xposed_init文件,然后写入hook类的全路径名,比如:
      com.pds.xposed.hook.XposedHookTest
      
    • 告诉xposed该module是一个xposed插件
      在manifest下的application标签下配置以下代码:
      <!-- 是否是xposed模块,xposed根据这个来判断是否是模块 -->
      <meta-data
            android:name="xposedmodule"
            android:value="true" />
      <!-- 模块描述,显示在xposed模块列表那里第二行 -->
      <meta-data
            android:name="xposeddescription"
            android:value=" HOOK TEST" />
      <!-- 最低xposed版本号(lib文件名可知) -->
      <meta-data
            android:name="xposedminversion"
            android:value="30" />
      
    • 安装并开启插件
      安装插件到手机上,然后打开上面安装的xposed软件,在模块里找到你自己的xposed插件,打开,重启系统。
    • 验证
      重启后,就可以验证自己插件是否生效或者自己hook逻辑是否有问题。

    修改变量

    如果我们想修改应用程序某一变量

    public void handleLoadPackage(XC_LoadPackage.LoadPackageParam paramLoadPackageParam) throws Throwable {
        // 通过包名判断,是不是我们要修改的应用
        if (HOOK_APP_PACKAGE_NAME .equals(packageParam.packageName)){
            // 找到变量所在的类文件
           final Class<?> clazz = XposedHelpers.findClass("com.pds.base.network.RetrofitConfig",classLoader);
            // 修改
            XposedHelpers.setStaticIntField(clazz,"level",2);
        }
    }
    

    加固

    现在很多应用都使用了第三方进行加固,这时候传入handleLoadPackage方法的XC_LoadPackage.LoadPackageParam参数中获取的ClassLoader是第三方加固程序的ClassLoader,如果用这个ClassLoader去找我们自己应用中的类,会报“类找不到”异常。

    而加固程序都会在自己的Application类里面做一些解密操作,我们可以hook加固程序的Application拿到应用真正的ClassLoader实例。下面以360加固讲解。

    360加固

    获取应用真正ClassLoader实现:

    private void _360Firm(final XC_LoadPackage.LoadPackageParam packageParam){
            //hook 360壳
            XposedHelpers.findAndHookMethod("com.stub.StubApp", packageParam.classLoader,"getOrigApplicationContext", Context.class, new XC_MethodHook() {
                @Override
                protected void afterHookedMethod(MethodHookParam param) throws Throwable {
                    super.afterHookedMethod(param);
                    XposedBridge.log("_360Firm afterHookedMethod");
                    //获取到360的Context对象,通过这个对象来获取classloader
                    Context context = (Context) param.args[0];
                    //获取360的classloader,之后hook加固后的代码就使用这个classloader
                    ClassLoader classLoader =context.getClassLoader();
                    //替换classloader,hook加固后的真正代码
                    hookMethod(packageParam,classLoader);
                }
     });
    

    由于第三方加固随时可能修改Application名,文件位置,方法名等,所以自己还是得知道怎么去分析。

    • 分析
      首先解压应用,拿到用于解密的未加固dex,使用工具反编译成jar,查看Application实现。然后对应修改就可以了。

    xposed插件推荐

    • Lucky Patcher
      Xposed module,具体各种破解功能,具网上资料,可以破解HttpCanary,但是我没有成功。

    • JustTrustMe
      Xposed module,关闭证书检测,这样https可以直接抓包。

    • BDOpener
      开启APK调试与备份选项的Xposed模块

    相关文章

      网友评论

        本文标题:【xposed】- 基础篇(1)

        本文链接:https://www.haomeiwen.com/subject/veigmhtx.html