【Frida】【Android】02_JAVA层HOOK

🛫 系列文章导航

  • 【Frida】【Android】01_手把手教你环境搭建 https://blog.csdn.net/kinghzking/article/details/136986950
  • 【Frida】【Android】02_JAVA层HOOK https://blog.csdn.net/kinghzking/article/details/137008446
  • 【Frida】【Android】03_RPC https://blog.csdn.net/kinghzking/article/details/137050967

▒ 目录 ▒

    • 🛫 系列文章导航
    • 🛫 导读
      • 开发环境
    • 1️⃣ Android App 代码介绍
      • 中文内部类和方法
      • 重载函数
      • 成员变量及静态函数
    • 2️⃣ 普通函数HOOK
      • Java.perform
      • 操作步骤
    • 3️⃣ 重载函数HOOK
    • 4️⃣ 构造函数HOOK
    • 5️⃣ 函数主动调用
    • 🛬 文章小结
      • frida api释义
    • 📖 参考资料

🛫 导读

开发环境

版本号描述
文章日期2024-03-24
操作系统Win11 - 22H222621.2715
node -vv20.10.0
npm -v10.2.3
夜神模拟器7.0.5.8
Android9
python3.9.9
frida16.2.1
frida-tools12.3.0
objection1.11.0

1️⃣ Android App 代码介绍

在本小节中,我们将开始学习Frida在Android Java中的Hook功能。为了清楚地了解App的运行内容,这里先编写一个简单的App用于练习。其主要使用逻辑为,通过点击测试按钮,触发各种函数调用。通过adb logcat | findstr yemao查看运行结果。
在这里插入图片描述

中文内部类和方法

该类逻辑相对简单,包含一个中文方法,内部打印一句话。
除此之外,编译器会生成一个默认的构造函数

在这里插入图片描述

设计这个类的原因有以下几点:

  • 演示普通函数HOOK
  • 演示构造函数HOOK
  • 为了测试中文相关名称处理方法
  • 演示子类Smali命名规则

重载函数

在入口类MainActivity中添加了两个相同名称的函数(重载函数),接受不同的参数,用于演示重载函数HOOK功能。

public class MainActivity extends AppCompatActivity {void fun(int x , int y ){Log.d("yemao.sum" , String.valueOf(x+y));}String fun(String x){return x.toLowerCase();}
}

成员变量及静态函数

除此之外,还预留了成员变量及静态函数,用于下面几个测试:

  • 修改成员变量
  • 主动调用静态函数
  • frida rpc测试
public class MainActivity extends AppCompatActivity {private String total = "hello";void secret(){total += " secretFunc";Log.d("yemao.secret" , "this is secret func");}static void staticSecret(){Log.d("yemao.secret" , "this is static secret func");}}

2️⃣ 普通函数HOOK

这里以com.yemao.demo.MainActivity.非重载测试类的方法普通函数为例,介绍普通函数HOOK,其它hook在此基础上进行解释。

Java.perform

用Frida的API函数Java.perform()将脚本中的内容注入到Java运行库,这个API的参数是一个函数,函数内容是监控和修改Java函数逻辑的主体内容。
注意,这里的Java.perform()函数非常重要,任何对App中Java层的操作都必须包裹在这个函数中,否则Frida运行起来后就会报错。


function main() {普通函数()重载函数()构造函数()函数主动调用()
}Java.perform(main)

操作步骤

  • 首先调用了Frida的API函数Java.use(),这个函数的参数是Hook的函数所在类的类名,参数的类型是一个字符串类型,比如Hook的中文方法()函数所在类的全名为com.roysue.demo02.MainActivity$非重载测试类,那么传递给这个函数的参数就是com.roysue.demo02.MainActivity$非重载测试类。这个函数的返回值动态地为相应Java类获取一个JavaScript Wrapper,可以通俗地理解为一个JavaScript对象。
    这里特别注意的是,内部类命名需要使用$连接!!!
  • 接着,通过JavaScript Wrapper获取其方法函数对象,有以下两种方法:
    • 如果是英文,直接通过.即可,例如cls.fun。(也可以使用cls['fun']
    • 对于中文,则需要使用[]获取方法对象:cls['中文方法']
  • 然后加上implementation 关键词表示实现,通过对其进行赋值,替换原有函数逻辑。
    通过this['中文方法']()函数再次调用原函数,并把原本的参数传递给这个函数。简而言之,就是重新执行原函数的内容,最后将这个函数的返回值直接通过return指令返回。

function 普通函数() {var cls = Java.use('com.yemao.demo.MainActivity$非重载测试类')console.log("Java.Use.Successfully!") //定位类成功!cls['中文方法'].implementation = function(x: number, y: number) {console.log("[普通函数] x => ",x,", y => ",y)// this['中文方法'] 可以获得Hook之前的函数,可以直接调用之前的函数// 这时候,可以根据自己的需求,修改参数等!!!var ret_value = this['中文方法'](x, y);return ret_value}
}

ps: 在Hook一个函数时,还有一个地方需要注意,那就是最好不要修改被Hook的函数的返回值类型,否则可能会引起程序崩溃等问题,比如直接通过调用原函数将原函数的返回值返回。

3️⃣ 重载函数HOOK

重载函数HOOK逻辑如果使用普通函数HOOK中的代码,会报错Error: fun(): has more than one overload。这是函数的重载导致Frida不知道具体应该Hook哪个函数而出现的问 题。 其 实 Frida 已 经 提 供 了 解 决 方 案 ( use .overload(<signature>), 就 是 指 定 函 数 签 名 , 将 报 错 中的.overload(‘java.lang.String’)者.overload(‘int’, ‘int’)添加到要Hook的函数名后、关键词implementation之前。


function 普通函数() {var MainAcitivity = Java.use('com.yemao.demo.MainActivity')console.log("Java.Use.Successfully!") //定位类成功!MainAcitivity.fun.overload('int', 'int').implementation = function(x: number, y: number) {console.log("[重载函数] x => ",x,", y => ",y)var ret_value = this.fun(x, y);return ret_value}
}

4️⃣ 构造函数HOOK

构造函数比普通函数,只有函数命名上特殊一点,frida采用了$init代表构造函数。
本例子使用的是内部类,相对于普通类,会多传递一个参数外部类对象,这是java语法特性,可以通过查看Smali代码看出该参数的传递,所以

  • 必须增加该参数mainAcitivity,否则程序会崩溃的!!!
  • 必须增加该参数mainAcitivity,否则程序会崩溃的!!!
  • 必须增加该参数mainAcitivity,否则程序会崩溃的!!!

function 普通函数() {var cls = Java.use('com.yemao.demo.MainActivity$非重载测试类')console.log("Java.Use.Successfully!") //定位类成功!cls.$init.implementation = function(mainAcitivity) {console.log("[构造函数] ===")var ret_value = this.$init(mainAcitivity);return ret_value}
}

5️⃣ 函数主动调用

在Java中,类中的函数可分为两种:类函数实例方法。通俗地讲,就是静态的方法和动态的方法。类函数使用关键字static修饰,和对应类是绑定的,如果类函数还被public关键词修饰着,在外部就可以直接通过类去调用;实例方法则没有关键字static修饰,在外部只能通过创建对应类的实例再通过这个实例去调用。
如果是类函数的主动调用,直接使用Java.use()函数找到类进行调用即可;
如果是实例方法的主动调用,则需要在找到对应的实例后对方法进行调用。这里用到了Frida中非常重要的一个API函数Java.choose(),这个函数可以在Java的堆中寻找指定类的实例。


function 函数主动调用() {var MainAcitivity = Java.use('com.yemao.demo.MainActivity')console.log("Java.Use.Successfully! 函数主动调用") //定位类成功!// 静态函数主动调用MainAcitivity.staticSecret();// Error: secret: cannot call instance method without an instance// MainAcitivity.secret();// 动态函数主动调用Java.choose('com.yemao.demo.MainActivity',{onMatch: function(instance){console.log('instance found',instance)instance.secret()},onComplete: function(){console.log('search Complete')}})
}

🛬 文章小结

frida api释义

函数名参数返回值含义
Java.perform函数任何对App中Java层的操作都必须包裹在这个函数
中,否则Frida运行起来后就会报错
Java.useclassNameJavaScript wrapper动态获取类实例对象
MainAcitivity.fun.implementation函数实现
MainAcitivity.fun.overload参数数组重载函数中,区分不同的函数
Java.chooseclassName, callbacks枚举className的实例对象,调用callbacks处理回调逻辑

📖 参考资料

  • 《安卓Frida逆向与抓包实战》
  • 【Frida】 00_简单介绍和使用 https://blog.csdn.net/kinghzking/article/details/123225580
  • 本节源码地址 https://gitcode.com/android8/AndroidFridaBeginnersBook

ps: 文章中内容仅用于技术交流,请勿用于违规违法行为。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/287571.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab编译成jar包

1、输入deploytool命令 2、选择Library Compiler 3、配置打包 4、有效文件 5、java函数调用 package com.beescloud.frame.matlab;import com.mathworks.toolbox.javabuilder.MWException; import test.Class1;public class MatlabTest {public static void main(String[] arg…

PanTools v1.0.17 多网盘批量管理 批量分享、转存、复制...

软件介绍 一款针对多个热门网盘的文件管理、批量分享、批量转存、批量复制、批量重命名、批量链接检测、跨账号移动文件、多账号文件搜索等&#xff0c;支持不同网盘的不同账号的资源文件操作。适用于网站站长、资源爱好者等&#xff0c;对于管理名下具有多个网盘多个账号具有…

UI风格汇:卡通风格(Cartoon Style),极具辨识度的风格

一、卡通风格的特点 卡通风格是一种在UI设计中常见的设计风格&#xff0c;它以卡通或漫画的形式呈现&#xff0c;具有夸张、可爱、幽默和生动的特点。卡通风格的UI设计通常使用明亮的色彩、简化的图形和夸张的表情来表达信息和情感。 以下是卡通风格在UI设计中的一些特点&…

【数字图像处理】改变图像灰度级别

改变图像灰度级别 首先&#xff0c;对原始图像 O O O进行灰度级量化: q int ⁡ ( O 2 i ) 2 i , q\operatorname{int}\left(\frac{O}{2^{i}}\right) \times 2^{i}, qint(2iO​)2i, 灰度级别256&#xff0c;128&#xff0c;64&#xff0c;32&#xff0c;16&#xff0c;8&…

是德科技KEYSIGHT MSOX2024A混合信号示波器

181/2461/8938产品概述&#xff1a; Keysight MSOX2024A 提供适合您预算的入门级价位&#xff0c;以及同类任何其他示波器所不具备的卓越性能和可选功能。凭借是德科技设计的 MegaZoom IV 定制 ASIC 技术&#xff0c;它每秒可提供高达 200,000 个波形。通过这种速度&#xff0…

Typescript语法总结

#Typescript 解决了什么问题 Typescript本质上是在 JavaScript 上增加一套静态类型系统&#xff08;编译时进行类型分析&#xff09;&#xff0c;强调静态类型系统是为了和运行时的类型检查机制做区分&#xff0c;TypeScript 的代码最终会被编译为 JavaScript。 Typescript 创造…

Multimodal Chain-of-Thought Reasoning in Language Models阅读笔记

论文&#xff08;2023年&#xff09;链接&#xff1a;https://arxiv.org/pdf/2302.00923.pdf GitHub项目链接&#xff1a;GitHub - amazon-science/mm-cot: Official implementation for "Multimodal Chain-of-Thought Reasoning in Language Models" (stay tuned a…

QToolButton的工具提示出现自身border-image背景图的问题解决

用QToolButton贴个图片&#xff0c;用来做个指示灯&#xff0c;当鼠标移动到指示灯&#xff0c;弹出工具提示&#xff0c;以便提示该灯用来干嘛的。预想像下面那样&#xff1a; 然而结果却如下&#xff1a; 在Qt Designer或代码中对该QToolButton设置样式表如下&#xff1a; QT…

中国国内怎么使用订阅升级Duolingo多邻国plus?多邻国使用教程

多邻国Duolingo合租平台&#xff0c;环球巴士 首单9折优惠码&#xff1a;110072 多邻国Duolingo是什么&#xff0c;能用来做什么&#xff1f; 众所周知&#xff0c;多邻国考试的性价比非常高&#xff0c;不仅考试时间短&#xff0c;出分也很快&#xff0c;国际认可度越来越高…

无人机采集图像的相关知识

1.飞行任务规划 一般使用飞行任务规划软件进行飞行任务的设计&#xff0c;软件可以自动计算相机覆盖和图像重叠情况。比如ArduPilot (ArduPilot - Versatile, Trusted, Open) 和UgCS (http://www.ugcs.com)是两个飞行任务规划软件&#xff0c;可以适用大多数无人机系统。 2.图…

教育行业信息数据化:探索8种不同的数据库类型及用途

前言 教育数据库是现代教育领域中不可或缺的重要工具&#xff0c;它们涵盖了多种类型&#xff0c;包括学生信息系统、学习管理系统、图书馆管理数据库、行政数据库、研究数据库、专业教育数据库等。这些数据库在教育机构中发挥着关键作用&#xff0c;为教育工作者和学生提供了…

探究 HTTPS 的工作过程

目录 1. HTTPS 协议原理 1.1. 为什么要有HTTPS协议 1.2. 如何理解安全 1.3. HTTPS 协议是什么 2. HTTPS 的前置概念 2.1. 什么是加密 && 解密 2.2. 为什么要加密 2.3. 常见的加密方式 2.3.1. 对称加密 2.3.2. 非对称加密 2.4. 数据摘要 && 数据指纹…

Git常用指令使用

摘要&#xff1a;之前代码管理都是借助于fork、sourceTree等图形工具&#xff0c;最近发现直接用命令也好用&#xff0c;就总结Git常用的指令 1、Git的介绍 1.1 git官网 安装: Git - Downloading Packagehttps://git-scm.com/download/mac Mac上安装&#xff0c;直接使…

蓝桥杯刷题8

1. 世纪末的星期 import java.util.Calendar; public class Main {public static void main(String[] args) {Calendar calendar Calendar.getInstance();for(int year 1999;year<100000;year100){calendar.set(Calendar.YEAR,year);calendar.set(Calendar.MONTH,11);cale…

【贪心]【字符串】【分类讨论】420 强密码检验器

本文涉及知识点 贪心 字符串 分类讨论 LeetCode420 强密码检验器 满足以下条件的密码被认为是强密码&#xff1a; 由至少 6 个&#xff0c;至多 20 个字符组成。 包含至少 一个小写 字母&#xff0c;至少 一个大写 字母&#xff0c;和至少 一个数字 。 不包含连续三个重复字…

数据结构——排序之冒泡排序

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

浏览器https受信任证书生成——openssl颁发受信任证书

站点常常由于没有受信任的第三方CA机构颁发证书,使用https访问时,浏览器常常会弹出不安全的提示,为解决该问题,可以使用openssl颁发个人证书来解决该问题。 1openssl安装及使用方式参考:32.9 x509_OpenSSL 中文手册https://www.openssl.net.cn/docs/230.html2.本文章所有生…

快速匹配和编译NXP官方uboot-imx

目录 概述 1 搭建编译环境 2 下载和编译uboot-imx 2.1 下载软件包 2.2 编译代码 3 总结 概述 本文主要讲述如何快速匹配和编译NXP官方uboot-imx。文中总结了生成u-boot文件的整个流程&#xff0c;笔者通过实操的方法&#xff0c;一步步从编译器下载&#xff0c;编译环境…

图像处理与视觉感知---期末复习重点(4)

文章目录 一、图像复原与图像增强1.1 概述1.2 异同点 二、图像复原/退化模型2.1 模型图简介2.2 线性复原法 三、彩色基础四、彩色模型五、彩色图像处理 一、图像复原与图像增强 1.1 概述 1. 图像增强技术一般要利用人的视觉系统特性&#xff0c;目的是取得较好的视觉效果&…

react native

简介 React Native 就是使用React和应用平台的原生功能来构建 Android 和 iOS 应用的开源框架。在 Android 和 iOS 开发中&#xff0c;一个视图是 UI 的基本组成部分&#xff0c;React 组件通过 JavaScript 来调用这些视图。可以构建自己的 Native Components(原生组件)&#…