zoukankan      html  css  js  c++  java
  • 从零开始Android逆向教程(二)——什么是Xposed

    前言
    在阅读本文之前,假设你的手机已经root,并且已经成功安装好了 XposedInstaller。   

    Xposed是什么?       
    Xposed 是一个 Android 平台上的动态劫持框架,通过替换手机上的孵化器 zygote 进程为 Xposed 自带的 zygote,使其在启动过程中加载 XposedBridge.jar,模块开发者可以通过 jar 提供的 API 来实现对所有的 Function(这里可以理解为方法) 的劫持,在原 Function 执行的前后加上自定义代码。 <ignore_js_op>
    Xposed框架是一款可以在不修改APK的情况下影响程序运行(修改系统)的框架服务,基于它可以制作出许多功能强大的模块,且在功能不冲突的情况下同时运作。Xposed理论上能够hook到系统任意一个Java进程,由于是从底层hook,所以需要root权限,并且每次更新都要重新启动,否则不生效 。

    Xposed 和 Cydia Substrate   
    这两个框架都是app注入的利器,只是相对来说有各自特点罢了。Cydia Substrate是一个代码修改平台。它可以修改任何主进程的代码,不管是用Java还是C/C++(native代码)编写的。而Xposed只支持 hook system/bin/app_process中的Java函数。其实Cydia Substrate 与xposed 的hook原理是一样的,二者都可以作为Java Hook的框架,看使用习惯了(iOS的越狱用到的便是Cydia Substrate)。笔者最近研究主要以Xposed为主,暂不对Cydia Substrate进行详细的说明,后续有研究会继续以文字形式记录吧。   

    利用Xposed执行最简单的篡改操作
    Xposed的运用太过广泛,作为这个系列的第一篇笔记,这里也介绍一种Xposed最简单的应用场景。   
    a. 随意在Android Studio里创建一个项目,在这里我的包名是:com.blues.cracktest 里面没有任何后续添加的代码,编译之后只有屏幕中间最经典的“Hello World!”;   
    b. 我们需要做的就是通过Xposed去修改这个“Hello World”,让它替换成任何我们想要它显示成为的东西,比如我期望是“Hello Xposed! ”        

    1. 首先第一步先进行配置,在清单文件AndroidManifest里 Application作用域里加上如下配置:    
    <meta-data            
      android:name="xposedmodule"            
      android:value="true" />        
    <meta-data           
      android:name="xposeddescription"            
      android:value="hello xposed" />        
    <meta-data            
      android:name="xposedminversion"            
      android:value="82" />   

    2.    第二步,在main目录下(java、res同级目录)创建assets文件夹,在该文件夹下新建一个xposed_init文件(该文件名称固定为xposed_init),该文件用于放置hook的入口,里面是一个路径(比如我的是com.blues.cracktest.XposedInit,XposedInit就是我hook的入口,这个类后面会提及)。  

    3.   第三步,新建一个类,这里就叫它XposedInit好了,让它实现(implements) IXposedHookLoadPackage 这个接口 ,重写 handleLoadPackage 方法(该方法用于获取需要hook到的类,里面会用到一个findAndHookMethod 用于hook对应的方法),我就直接show code吧:        
    public class XposedInit implements IXposedHookLoadPackage {   @Override  public void handleLoadPackage(final XC_LoadPackage.LoadPackageParam lpparam) {      if (lpparam.packageName.equals("com.blues.cracktest")) {
              XposedHelpers.findAndHookMethod("com.blues.cracktest.MainActivity", lpparam.classLoader, "onCreate", Bundle.class, new XC_MethodHook() {
                  @Override
                  protected void afterHookedMethod(XC_MethodHook.MethodHookParam param) throws Throwable {
                      //不能通过Class.forName()来获取Class ,在跨应用时会失效
                      Class c = lpparam.classLoader.loadClass("com.blues.cracktest.MainActivity");
                      Field field = c.getDeclaredField("textView");
                      field.setAccessible(true);
                      //param.thisObject 为执行该方法的对象,在这里指MainActivity
                      TextView textView = (TextView) field.get(param.thisObject);
                      textView.setText("Hello Xposed!");
                  }
              });
          }
      }
    &#8203;
    }



    &#8203;原来的MainActivity长这样:
    public class MainActivity extends AppCompatActivity {&#8203;
       private TextView textView;


      @Override
      protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.activity_main);
          textView = findViewById(R.id.text);
          textView.setText("Hello,World!");
      }

  • 相关阅读:
    docker架构的详解
    docker的核心原理-cgroup
    网络运维面试题
    100道linux运维笔试题
    运维岗位面试题集合
    python——筛子游戏
    同道前辈
    delphi中使用SocketStream读写数据的技巧
    百度地图API
    HTML中小meta的大作用
  • 原文地址:https://www.cnblogs.com/nongchaoer/p/11843549.html
Copyright © 2011-2022 走看看