一目录结构

├── test.py  #py脚本
└── test.js #js脚本

一.py脚本

test.py

import frida
import sys
#连接设备app
dev=frida.get_usb_device() # get_usb_device获取设备
PACKAGE = 'cn.soulapp.android' # 包名
process = dev.attach(PACKAGE) # 获取给定包名的app进程 #运行脚本
#获取js脚本内容
with open('test.js', 'r') as fr:
js_test=fr.read()
script = process.create_script(js_test) # 这里是把你的js脚本给塞进了process #可以获取打印效果
def show(message,data):
print(message)
script.on("message",show) # 加载脚本
script.load()
sys.stdin.read()

二.js脚本

Java.perform(function(){    //固定写法所有脚本就要丢在里面
var c =Java.use('cn.soulapp.android.utils.j'); //Java.use获取cn.soulapp.android.utils.j这个类
c.e.implementation =function(a){return false}; //类的方法复制
});

三.frida相关接口

一.Java.perform(function()

返回值:空

用途:这是frida的main,所有的脚本必须放在这个里面

二. Java.use(类名)

返回值:类的对象

用途:动态获取一个类的对象

拓展:$new()实例化对象$dispose()销毁对象

三.Java.available

返回值:boolean。

用途:确认当前进程的java虚拟机是否已经启动,虚拟机包括Dalbik或者ART等。虚拟机没有启动的情况下不要唤醒其他java的属性或者方法。

四.Java.enumerateLoadedClasses(callbacks)

返回值:无

参数:回调函数

用途:列出当前已经加载的类,用回调函数处理

回调函数:

onMatch:function(className){ }

找到加载的每个类的时候被调用,参数就是类的名字,这个参数可以传给java.use()来获得一个js类包

onComplete: function ():

列出所有类之后被调用 ,也就是完成后做一些扫尾工作

五.Java.enumerateLoadedClassesSync()

返回值:所有已经加载的类的数组。

六.Java.scheduleOnMainThread(function()

返回值:无

用途:在线程上运行指定的函数

七.Java.choose(className, callbacks):

用途:查找堆中指定类的实例。获得实例后可以调用实例的函数

回调函数

onMatch: function (instance)

每次找到 指定类的实例后调用,

onComplete: function ()

完成时调用

八.Java.cast(handle, klass)

返回值:类的对象

参数:句柄(ptr),klass(use()的返回值)

用途:用来获取 指定内存地址的类的实例 的对象。这个对象有类属性,可以得到所属类的对象。还有$className属性过去类名的字符串。一个对象有可能有很多实例

例子:

var Activity = Java.use("android.app.Activity");

var activity = Java.cast(ptr("0x1234"), Activity);

四.总结

java接口的api中,perform是必须用,没什么实际作用。use是最常用的,用来获取类的对象,获取对象后就可以替换具体方法的实现了,相当于修改源码!!choose和cast是针对运行时对象的实例,相当于动态调试过程中获取信息。

最新文章

  1. nf_conntrack被启用导致服务故障
  2. js对象的创建与原型总结
  3. AX 2012 SSRS print setting-报表打印输出设置
  4. 通过JS语句判断WEB网站的访问端是电脑还是手机
  5. Android开发之ListView-ArrayAdapter的使用
  6. [转] 如何在 Ubuntu 14.04 上通过 apt-get 安装 Apache Tomcat 7
  7. 《神经网络和深度学习》系列文章三:sigmoid神经元
  8. 关于初学者上传文件到github的方法
  9. 01--从根源种子CCNode说起
  10. C++对象模型--总结
  11. jQuery+HTML5声音提示
  12. allocator 类
  13. Android学习笔记-Adapter基础讲解
  14. ESP8266开发综合篇(SDK开发-视频教程总揽)
  15. 主窗口QMainWindow和启动画面
  16. js知识点: 数组
  17. [转]HIVE UDF/UDAF/UDTF的Map Reduce代码框架模板
  18. ubuntu中apache2的安装与卸载
  19. 过虑器应用之1-设置request编码
  20. PHP操作redis之String(字符串)、List(列表)(一)

热门文章

  1. vue学习(九) 使用内联样式设置style样式
  2. 无法安装 VMware Tools。尝试访问安装 VMware Tools 所需的图像文件“/usr/lib/vmware/isoimages/linuxPreGlibc25.iso”时出错: 2 (No such file or directory)。请参考产品文档或知识库文章 2129825,了解关于如何获取该客户机操作系统的 VMware Tools 软件包的详细信息。
  3. go项目dockerfile最佳实践
  4. 【JMicro】微服务开发及使用
  5. PHP fgetc() 函数
  6. PHP stripos() 函数
  7. Java分层领域模型的DO、DTO、BO、AO、VO、POJO、Query定义
  8. Python10行以内代码能有什么高端操作
  9. 注重代码习惯,Python零基础从这本书籍开始!
  10. 理解JavaScript的原型链