frida hook实例

上一篇简单介绍了frida安装,这一章说一下frida的简单调用,直接上代码

使用工具
rps.apk(这是一个石头剪刀布的游戏应用)
mumu模拟器

rps.apk下载链接:https://pan.baidu.com/s/1dlfdrr0dTAJcuAx6M4cLEQ
提取码:6g93

启动./frida-server 服务后,执行如下代码。

python脚本注入方式

import frida, sys

def on_message(message, data):
    if message['type'] == 'send':
        print("[*] {0}".format(message['payload']))
    else:
        print(message)

jscode = """
    Java.perform(function () {
        var MainActivity = Java.use('com.example.seccon2015.rock_paper_scissors.MainActivity');
        MainActivity.onClick.implementation = function (v) {
            send("Hook Start...");

            # 不改变参数v的情况下,直接调用原方法onClick(v),这样不妨碍程序原本的运行
            # 如果想要修改参数,也是在此处直接对v进行修改。
            this.onClick(v);

            # 程序中代码的变量可以随意修改
            this.n.value = 0;
            this.m.value = 2;
            this.cnt.value = 999;

            # 以下两种方式都能打印
            send("Success!")
            console.log("Success!")
        }
    });
    """
process = frida.get_usb_device(1000).attach('com.example.seccon2015.rock_paper_scissors')
script = process.create_script(jscode)
script.on('message', on_message)
script.load()
sys.stdin.read()

使用jadx-gui反编译,可以看到onClick源码如下:
在这里插入图片描述

启动apk,界面上有R,P,S按钮,比如点击R按钮,会出现如下图所以:
在这里插入图片描述

代码会如下图所示:
在这里插入图片描述

到此运行成功。

本章没有过多的介绍hook的理论知识,就是一个简单的入门代码,可以直接运行,感受一下frida如何hook。

有时间再详细的介绍frida+hook的一些常用方法和实例。

Frida是一种针对Android应用程序的动态插桩工具。它允许开发者使用JavaScript进行代码注入和修改,以实现对目标应用程序的动态分析和修改。其中一个常见的用途就是使用Frida来钩取(Hook)Bitmap对象。 Bitmap是Android中用于表示图像的类,可以用来处理和操纵图像像素数据。通过使用FridaHook Bitmap对象,我们可以实时监控和修改应用程序中的图像数据。 要实现Bitmap的Hook,首先需要在目标应用程序中找到Bitmap对象的实例,可以通过遍历应用程序中的所有对象,筛选出Bitmap对象,或者根据特定的条件来搜索。一旦找到了Bitmap对象的实例,就可以通过Frida提供的API来Hook该对象,以获得对其数据的访问权限。 通过Hook Bitmap对象,可以进行多种操作,例如: 1. 实时监控:可以在Bitmap对象上注册监听器,以便实时监视图像的变化,例如检测图像是否被修改或篡改。 2. 数据修改:可以直接修改Bitmap对象的像素数据,例如改变图像的颜色、大小或者进行图像特效处理。 3. 数据拷贝:可以将Bitmap对象的数据拷贝到本地内存中,以便对图像数据进行离线处理。 4. 数据分析:可以通过Hook Bitmap对象,获取图像的像素数据,并进行进一步的分析、统计或处理,例如提取图像中的特征。 总之,通过Frida Hook Bitmap,我们可以对Android应用程序中的图像数据进行实时监控和修改,以实现各种图像相关的操作和分析。这对于应用程序的开发、逆向工程和安全分析都具有重要意义。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值