15.安卓逆向-frida基础-HOOK类方法1

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动!

内容参考于:图灵Python学院

本人写的内容纯属胡编乱造,全都是合成造假,仅仅只是为了娱乐,请不要盲目相信。

工具下载:

链接:https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd=6tw3

提取码:6tw3

复制这段内容后打开百度网盘手机App,操作更方便哦

上一个内容:14.安卓逆向-frida基础-编写hook脚本2

上一个内容里写了Frida的脚本语法怎么玩着,本次接着上一个内容进行实操,搞在逆向的时候HOOK的一些东西

比如:

hook okhttp的方法 HttpUrl、Request、addHeader,通过hook HttpUrl方法得到请求地址,通过hook Request得到请求和相应,通过hook addHeader得到请求头

hook json数据,有些app会把参数放到json里面去,app和服务器交互通过会使用json格式

hook 排序算法,有些app会把参数放到排序算法中

hook String字符串转换,有的app在加完密之后会使用String的方法进行转字符串

hook StringBuilder,有些app会使用StringBuilder添加参数

hook 按钮点击事件

然后首先是hook java特殊类型

`下图红框位置它有使用HashMap

然后上图红框里调用了show方法,下图show方法的内容,做的是把Map里的数据拿出来用StringBuilder进行拼接,然后如果想看东西的话,需要hook show方法

代码和效果图:

function demo1(){
    var utils = Java.use("com.luoge.com.BufferMap")
    utils.show.implementation = function(map){
        console.log("\n")
        console.log("参数1--》"+map)
        // console.log("\n")
        var res = this.show(map)
        console.log("返回值--》"+res)
        return res
    }
}


Java.perform(function (){ // 调用java代码也就是getCalc方法
    demo1()
})

Map类型取值一般要用下方红框的写法

function demo1(){
    var utils = Java.use("com.luoge.com.BufferMap")
    utils.show.implementation = function(map){
        console.log("\n")
        var key = map.keySet()
        var it = key.iterator()
        var result = ""
        while(it.hasNext()){
            var keystr = it.next()
            var valuestr = map.get(keystr)
            result += valuestr
        }

        console.log("循环处理的数据:", result)


        console.log("参数1--》"+map)
        // console.log("\n")
        var res = this.show(map)
        console.log("返回值--》"+res)
        return res
    }
}


Java.perform(function (){ // 调用java代码也就是getCalc方法
    demo1()
})

向map里添加数据

function demo1(){
    var utils = Java.use("com.luoge.com.BufferMap")
    utils.show.implementation = function(map){
        console.log("\n")
        var key = map.keySet()
        var it = key.iterator()
        var result = ""
        while(it.hasNext()){
            var keystr = it.next()
            var valuestr = map.get(keystr)
            result += valuestr
        }

        console.log("循环处理的数据:", result)

        map.put(" 添加的k", " 添加的值")
        console.log("参数1--》"+map)
        // console.log("\n")
        var res = this.show(map)
        console.log("返回值--》"+res)
        return res
    }
}


Java.perform(function (){ // 调用java代码也就是getCalc方法
    demo1()
})

hook okhttp

hook请求抓包,有些抓包软件抓不到东西,这就需要采用hook 发送请求的类来抓包,这里hook okhttp,如果app不用okhttp它也是没办法抓包

function demo2() {// hook 请求
    var Builder = Java.use("okhttp3.Request$Builder")
    Builder.newCall.overload('okhttp3.HttpUrl').implementation = function (a){
       console.log()
       var res = this.url()
       return res
    }
}

function demo3() {// hook 请求和响应
    var OkHttpClient = Java.use("okhttp3.OkHttpClient")
    OkHttpClient.newCall.overload('okhttp3.Request').implementation = function (a){
        console.log()
        console.log("入参:", a.url().toString())// 请求地址
        var call = this.newCall(a)
        console.log("newCall")
        var response = call.execute();
        console.log("返回值:", response.body().string())// 请求返回值
        return call
    }
}

function demo4(){ // hook请求头
    var Builder = Java.use("okhttp3.Request$Builder")
    Builder["addHeader"].implementation = function (str1, str2){
        console.log("key:", str1)
        console.log("val:", str2)
        var result = this["addHeader"](str1, str2)
        return  result
    }


}

function demo5() {// hook 请求和响应
    var OkHttpClient = Java.use("okhttp3.OkHttpClient")
    OkHttpClient.newCall.overload('okhttp3.Request').implementation = function (request){
        console.log()
        console.log("请求地址:", request.url().toString())// 请求地址

        var headers = request.headers() // 获取请求头
        console.log("请求头:", headers.toString())

        var method = request.method()// 获取请求的方式,post、get
        console.log("请求方式:",method)
        var requestBody = request.body()
        if(requestBody === null){
            return this.newCall(request)
        }
        const FormBody = Java.use("okhttp3.FormBody")// 获取表单
        if(request.method() !== null && requestBody.getClass()!==null && requestBody.getClass().getName() === "okhttp3.FormBody"){
            var formBody = Java.cast(requestBody, FormBody)// cast是用来转类型的,它会把requestBody转成FormBody类型
            console.log("请求体(Body)")
            for (var i = 0; i < formBody.size(); i++) {
                console.log(formBody.name(i)+":"+formBody.value(i))
            }
        }

        return this.newCall(request)
    }
}

Java.perform(function (){ // 调用java代码也就是getCalc方法
    // demo1()
    // demo2()
    demo5()
})


img

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WEB服务器——Tomcat

服务器是可以使用java完成编写&#xff0c;是可以接受页面发送的请求和响应数据给前端浏览器的&#xff0c;而在开发中真正用到的Web服务器&#xff0c;我们不会自己写的&#xff0c;都是使用目前比较流行的web服务器。 如&#xff1a;Tomcat 1. 简介 Tomcat 是一个开源的轻量…

【CAM350】使用总结 <二>{ 光绘Gerber 比较 }

一、 比较两份版本不同的光绘文件&#xff1a; //Analysis-Compare layers// 二、参数默认&#xff0c;比较完成给出结果 三、也可以直接在一份文件上选择“Draw on top” 四、对比差距直观可见

家中浮毛太多怎么办?希喂、米家、安德迈更推荐哪款?

在现代养宠家庭生活中&#xff0c;宠物空气净化器已经成为不可或缺的家电之一。 而在众多空气净化器类型中&#xff0c;宠物空气净化器以其独特的设计和卓越的净化效果&#xff0c;逐渐赢得了越来越多养宠家庭的青睐。 它不仅能有效地吸附空中飞舞的浮毛&#xff0c;还能高效…

基于SSM+小程序的在线课堂微信管理系统(在线课堂1)(源码+sql脚本+视频导入教程+文档)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 &emsp1、管理员实现了首页、个人中心、用户管理、课程分类管理、课程信息管理、课程订阅管理、课程视频管理、公告栏管理、留言板管理、系统管理。 2、用户实现了首页、课程信息、公…

此连接非私人连接

当你手机浏览器输入网站打开提示“此连接非私人连接&#xff0c;此网站可能在冒充来窃取你的个人或财务信息。你应回到之前的页面”这是因为该网站的SSL数字证书到期导致&#xff0c;需要此网站的管理员重新申请数字证书替换之前的文件才可以实现。 注意&#xff1a;如果你不是…

实用SQL小总结

WHERE 条件 column 为纯英文字符 或 不包含任何字符 语法&#xff1a; SELECT * FROM your_table WHERE REGEXP(your_column,^[A-Za-z]$); SELECT * FROM your_table WHERE NOT REGEXP(your_column,^[A-Za-z]$);例&#xff1a; SELECT DISTINCT t.pldlibho FROM kibb_pldlyw…

LLM - 使用 vLLM 部署 Qwen2-VL 多模态大模型 (配置 FlashAttention) 教程

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/142528967 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 vLLM 用…

02-ZYNQ linux开发环境安装,基于Petalinux2022.2和Vitis2022.2

petalinux安装 Petalinux 工具是 Xilinx 公司推出的嵌入式 Linux 开发套件&#xff0c;包括了 u-boot、Linux Kernel、device-tree、rootfs 等源码和库&#xff0c;以及 Yocto recipes&#xff0c;可以让客户很方便的生成、配置、编译及自定义 Linux 系统。Petalinux 支持 Ver…

uniapp EChars图表

1. uniapp EChars图表 &#xff08;1&#xff09;Apache ECharts 一个基于 JavaScript 的开源可视化图表库   https://echarts.apache.org/examples/zh/index.html &#xff08;1&#xff09;官网图例 &#xff08;2&#xff09;个人实现图例 1.1. 下载echart 1.1.1. 下…

docker - 迁移和备份

文章目录 1、docker commit1.1、查询 容器 docker ps1.2、docker commit zookeeper zookeeper:3.4.13 2、docker save -o2.1、宿主机 切换到 /opt 目录下2.2、将镜像保存到 宿主机/opt目录下 3、docker load -i 对某一个容器修改完毕以后&#xff0c;我们可以把最新的容器部署到…

【文心智能体 | AI大师工坊】如何使用智能体插件,完成一款旅游类智能体的开发,来体验一下我的智能体『​​​​​​​厦门CityWalk』

目录 1.1、智能体运行效果 1.2、创作灵感来源 1.3、如何制作智能体 1.4、可能会遇到的几个问题 1.5、快速调优指南 『厦门CityWalk&#x1f680;』我的优质智能体&#xff1a;https://0nxj3k.smartapps.baidu.com/?_swebfr1&_swebScene3621000000000000 在当今这个全…

Bytebase 2.22.3 - 一键回滚 PostgreSQL DML 变更

&#x1f680; 新功能 支持一键回滚 PostgreSQL DML 变更。 &#x1f384; 改进 优化 DML 事前备份和回滚体验&#xff1a; 引导用户创建 bbdataarchive 数据库。如果没有 bbdataarchive 数据库&#xff0c;无法开启备份功。用户现在可以在创建工单之后开启或关闭备份功能&a…

Python | Leetcode Python题解之第437题路径总和III

题目&#xff1a; 题解&#xff1a; class Solution:def pathSum(self, root: TreeNode, targetSum: int) -> int:prefix collections.defaultdict(int)prefix[0] 1def dfs(root, curr):if not root:return 0ret 0curr root.valret prefix[curr - targetSum]prefix[cu…

ROS学习笔记(四):使用 `ros2 run usb_cam usb_cam_node_exe` 启动 USB 摄像头

文章目录 前言1 安装 usb_cam 包2 启动 USB 摄像头3 订阅相机发布的节点信息并进行可视化3.1 使用 rqt_image_view3.2 使用 image_view3.3 使用 rviz 4 常见问题与解决方案4.1 摄像头未被识别4.2 相机显示异常4.3 如何指定不同的相机4.4 摄像头参数调整 5. 调试信息 5. 结论 前…

9.5K Star,开源在线网盘

Hi&#xff0c;骚年&#xff0c;我是大 G&#xff0c;公众号「GitHub 指北」会推荐 GitHub 上有趣有用的项目&#xff0c;一分钟 get 一个优秀的开源项目&#xff0c;挖掘开源的价值&#xff0c;欢迎关注。 随着云存储的广泛应用&#xff0c;越来越多的人和企业需要一个简单、…

用Promise实现前端并发请求

/** * 构造假请求 */ async function request(url) {return new Promise((resolve) > {setTimeout(() > {resolve(url);},// Math.random() * 500 800,1000,);}); }请求一次&#xff0c;查看耗时&#xff0c;预计应该是1s&#xff1a; async function requestOnce() {c…

docker安装Portainer CE

docker安装Portainer CE 教程 1、简介 Portainer 是一款开源的容器管理工具&#xff0c;旨在帮助用户更轻松地管理 Docker 环境。无论您是 Docker 新手还是经验丰富的开发人员&#xff0c;Portainer 都提供了直观的用户界面&#xff0c;使您能够方便地创建、部署和监控容器。…

黑马头条day5- 延迟任务精准发布文章

这个过程主要是流程负责 但是我没有仔细的过所有的流程 需要多刷几遍 今天只是照着md文档执行了一下 运行起来没差错 主要实现文章定时发布 通过schedule模块作为延迟队列的任务 通过redis实现的延迟任务 具体 实现还要在多走几遍流程 逻辑一点不清楚 没看网课 这节要多看几遍…

Redis 篇-深入了解 Redis 中的 RESP 通信协议与内存回收(过期 key 处理、内存淘汰策略)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 Redis 通信协议 - RESP 协议 2.0 Redis 内存回收 2.1 Redis 内存回收 - 过期 key 处理 2.1.1 Redis 是如何知道一个 Key 是否过期呢&#xff1f; 2.1.2 是不是 TT…

GESP等级考试C++二级-数学函数

C的cmath库中有丰富的数学函数&#xff0c;通过这些函数可以进行相应的数学计算。 1 cmath库的导入 通过import指令导入cmath库&#xff0c;代码如图1所示。 图1 导入cmath库的代码 2 abs()函数 abs()函数用来获取指定数的绝对值&#xff0c;代码如图2所示。 图2 abs()函数…