Xposed框架实现Android中的Hook

Hook.jpg

前几天受高人指点意外发现了开启Android世界的新大陆,就是这个叫Hook(''钩子'')的东西。听起来很神奇,周末抽时间研究了一番,发现确实是一个值得去研究的技术。


什么是 Hook?

江湖上称它为“钩子”,它能够在事件传送到终点前截获并监控事件的传输。它能够将自己的代码“融入”被钩住的进程中,成为目标进程的一部分。这么说来,它可以Hook住系统的API,然后通过注入自己代码的方式去改变系统方法的行为、以及对系统方法的监听;除此以外,它还能通过实现一个程序,去篡改其他应用程序的行为。

原理:Hook技术本质是函数调用,由于处于Linux用户状态,每个进程有自己独立的进程控件,所以必须先注入所要Hook的进程空间,修改其内存中进程代码,替换过程表的符号地址,通过ptrace函数附加进程,向远程进程注入so库,从而达到监控以及远程进程关键函数挂钩


Xposed框架

要是说起这个框架,那可就真的牛逼了。什么微信自动抢红包、微信步数作弊......这些骚操作都是这个框架干出来的。
在Android系统中,应用程序进程以及系统服务进程都是由Zygote 进程 fork 出来的。Xposed框架深入到Android核心机制中,正式通过改造Zygote 进程来实现一系列的操作。
其使用方法我这里不做过多的说明,百度就能有一大堆的使用教程。

关于Xposed框架的具体实现原理,我建议可以参考Dalvik虚拟机原理及Xposed hook原理这篇文章。


劫持登录Demo

又是这个栗子...不过不要紧,我们最重要的是学习原理和用法,一通百通。

  btnHook.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String userName = etUserame.getText().toString();
                String userPassword = etPassword.getText().toString();
                if (checkInfo(userName, userPassword)) {
                    Toast.makeText(getApplicationContext(), "登录成功", Toast.LENGTH_SHORT).show();
                } else {
                    Toast.makeText(getApplicationContext(), "登录失败", Toast.LENGTH_SHORT).show();
                }
            }
        });

private boolean checkInfo(String userName, String userPassword) {
        return userName.equals("jy") && userPassword.equals("123");
    }

我模拟了一个登录的情景,并规定只有输入用户名和密码分别是jy和123的条件下才能正常登录。
为了实现劫持登录的效果,这里新建一个类去实现 IXposedHookLoadPackage,然后重写 handleLoadPackage 方法。

 /**
     * 包加载时候的回调
     */

    @Override
    public void handleLoadPackage(XC_LoadPackage.LoadPackageParam lpparam) throws Throwable {

        XposedBridge.log("Loaded app : " + lpparam.packageName);

        XposedHelpers.findAndHookMethod("cn.edu.hrbeu.jy.hooktest.MainActivity", lpparam.classLoader, "checkInfo",
                String.class, String.class, new XC_MethodHook() {
                    @Override
                    protected void beforeHookedMethod(MethodHookParam param) throws Throwable {
                        XposedBridge.log("hook start");
                        XposedBridge.log("参数1: " + param.args[0]);
                        XposedBridge.log("参数2: " + param.args[1]);
                    }

                    @Override
                    protected void afterHookedMethod(MethodHookParam param) throws Throwable {
                        XposedBridge.log("劫持前返回的result: " + param.getResult());
                        param.setResult(true);
                        XposedBridge.log("劫持后返回的result: " + param.getResult());
                        XposedBridge.log("hook finish");
                    }
                });
    }

在启动了任意应用程序之后,都会执行一次这个方法,然后根据 packageName 来找到你需要去Hook的某个app的某个方法。这里,我找到了我的 MainActivity 以及验证登录信息的 checkInfo() 方法。
findAndHookMethod()中有两个回调方法,根据名字可以看出一个是方法执行前的回调,另一个是方法执行之后的回调。

先来看看程序界面和运行结果:

11111111.png
执行结果.png

可以看到的是,我输入的内容与我之前设定的账号密码并不同,但还是显示了登录成功。来简单分析一下:

首先,我输入了错误的账号密码,所以正常情况我的checkInfo()方法会返回 false 。所以劫持前的result 会返回 false,就像Log日志里面的一样。然后我将 param.setResult(true);将返回的结果设置成了 true...再作为最终的结果返回,所以说无论我输入什么都会显示登录成功...


分析

虽然我做的只是最简单的修改了自己实现的方法,但是其实无论是系统API 还是说别的app里面的方法,只要知道方法名和参数类型,理论上我们都可以去Hook住它们,并且可以监听或者修改这些方法的一些行为。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,522评论 25 707
  • 安全博客 > 技术研究 > 浅谈android hook技术 浅谈android hook技术 您当前的位置:...
    光剑书架上的书阅读 6,146评论 0 8
  • 前言 Xposed这位老兄大家可能不认识,微信自动抢红包大家听过吧、微信记录器作弊大家听过吧、地理位置模拟大家听过...
    王永迪阅读 30,856评论 15 62
  • 嘿!亲爱的老爸,我爱你。 前几天和发小聊天,她对我讲:小卿,还记得小时候去你家玩,在你家院子里画个圈圈玩捉迷藏的游...
    愿与卿语阅读 462评论 0 4
  • 数据可视化的意义 1. 表达观点 人类是视觉动物,一张简单的数据可视化图表在传递大量信息的同时,能更加直观地阐述观...
    耗子吴阅读 2,565评论 1 21