10.安卓逆向2-frida hook技術-frida基本使用-frida指令(用于hook)

免責聲明:內容僅供學習參考,請合法利用知識,禁止進行違法犯罪活動!

內容參考于:圖靈Python學院

工具下載:

鏈接:https://pan.baidu.com/s/1bb8NhJc9eTuLzQr39lF55Q?pwd=zy89

提取碼:zy89

復制這段內容后打開百度網盤手機App,操作更方便哦

上一個內容:9.安卓逆向2-frida hook技術-frida基本使用-frida-ps指令

frida的hook主要是學習下圖紅框的參數,也并不需要全部學習,常用的就那幾個

-U

使用usb線連接

frida -U

-f

指令app包名

-p

使用app的pid

-l

加載 hook腳本

-o

把腳本輸出的信息保存到文件中

frida兩種操作模式

cli命令行,javascript腳本注入進程

rpc,Python進行javascript腳本注入

frida兩種操作app的方式

spwan模式,不管app運不運行它都會重啟,然后注入,它的注入比較早,就是可以攔截app啟動時執行的代碼

attach模式,給一個正在運行的app進行注入,也就是說只有app運行了它才能進行注入,它比較晚,app啟動時的代碼沒辦法攔截(運行之后才注入怎么可能攔截啟動時的代碼)

到底是用spwan模式還是attach模式,-f指定包名 使用spwan模式,加了-f就會使用spwan模式,加-F使用attach模式

frida腳本都是使用JavaScript語言編寫,它有個固定格式

Java.perform(function () {});

首先啟動一下手機里的 frida-server

attach模式注入腳本 frida -UF -l .\FridaHook初體驗.js

Java.perform(function () {// 獲取當前應用的上下文var currentApplication = Java.use('android.app.ActivityThread').currentApplication();var context = currentApplication.getApplicationContext();// 獲取包名var packageName = context.getPackageName();// 輸出包名console.log("當前應用的包名是: " + packageName);send(packageName)
});

直接寫exit然后按回車鍵(Enter鍵)退出hook

使用Python啟動腳本

核心是通過 frida.get_usb_device()獲取frida功能

然后使用device.get_process("com.xxx.frodo").pid 獲取app進程id

然后寫JavaScript的hook腳本

js_cpde = '''
Java.perform(function () {// 獲取當前應用的上下文var currentApplication = Java.use('android.app.ActivityThread').currentApplication();var context = currentApplication.getApplicationContext();// 獲取包名var packageName = context.getPackageName();// 輸出包名console.log("當前應用的包名是: " + packageName);
});
'''

然后使用 session.create_script(js_cpde) 加載腳本

然后使用 script.load() 把腳本注入到app中并執行腳本

spwan模式

指令 frida -Uf com.XXX.frodo -l .\FridaHook初體驗.js

執行了上面的指令后會卡主,然后輸入 %resume讓app繼續運行

Python使用spwan模式,,主要修改了下圖紅框的兩行代碼

# -*- coding: utf-8 -*-
import frida
import sysdef on_message(message, data):print("message", message)print("data", data)# 通過Spawn模式啟動一個新的應用程序進程,并在該進程中加載Frida腳本
device = frida.get_usb_device()pid = device.spawn(["com.trs.xxxx.xxx"])
# 恢復應用程序的執行
device.resume(pid)session = device.attach(pid)js_cpde = '''
Java.perform(function () {// 獲取當前應用的上下文var currentApplication = Java.use('android.app.ActivityThread').currentApplication();var context = currentApplication.getApplicationContext();// 獲取包名var packageName = context.getPackageName();// 輸出包名console.log("當前應用的包名是: " + packageName);send(packageName)
});
'''script = session.create_script(js_cpde)
# 設置監聽
script.on("message", on_message)
script.load()
# 阻塞主線程,以保持腳本運行
sys.stdin.read()

還有如下圖紅框

使用 script.on("message", on_message)設置監聽message消息,然后通過 send(packageName)的send函數觸發on_message函數,這樣就可以在Python代碼中獲取JavaScript里的數據

frida遠程模式,一般不使用,它有點麻煩

首先使用把剛剛啟動的frida-server按CTRL+C進行退出,然后使用 ./frida-server-14.2.18-android-arm64 -l 0.0.0.0:8881指定frida-server的端口為8881啟動

然后使用 adb forward tcp:8881 tcp:8881 指令映射端口(或者理解為開啟端口)

然后這時的客戶端指令,不是-U使用-H了,別的沒變化

Python使用frida的遠程模式

# -*- coding: utf-8 -*-import frida, sysjsCode = """
Java.perform(function () {// 獲取當前應用的上下文var currentApplication = Java.use('android.app.ActivityThread').currentApplication();var context = currentApplication.getApplicationContext();// 獲取包名var packageName = context.getPackageName();// 輸出包名console.log("當前應用的包名是: " + packageName);
});
"""def message(message, data):if message['type'] == 'send':print(f"[*] {message['payload']}")else:print(message)# 遠程連接服務端
device = frida.get_device_manager().add_remote_device('127.0.0.1:8881')
# 附著到已運行的應用
process = device.attach('com.trs.xxx.newsclient')
script = process.create_script(jsCode)
script.on("message",message)
script.load()

img

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83193.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83193.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83193.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

LLM-MPC混合架構:車載大語言模型用來增強自動駕駛系統

1. 概述 2025年,蘇黎世研究團隊在RSS2025會議上正式提出「LLM-MPC混合架構」,標志著大語言模型(LLM)在自動駕駛系統中的實用化邁出關鍵一步。該方案旨在解決傳統深度學習模型在極端交通場景中泛化能力不足的問題。通過在車載終端…

解釋k8s種ConfigMap和Secret的作用,如何在Pod中掛載環境變

一、ConfigMap & Secret 核心定位 屬于Kubernetes的配置管理特性,用于解耦應用與配置 1. ConfigMap 作用:存儲非敏感配置數據 存儲內容: 環境變量命令行參數配置文件(如JSON/XML/YAML)系統參數(如J…

Android --- ObjectAnimator 和 TranslateAnimation有什么區別

文章目錄 2. 作用范圍和功能2. 動畫表現3. 是否修改 View 的屬性4. 適用場景5. 性能總結: ObjectAnimator 和 TranslateAnimation 都是 Android 中常用的動畫類型,但它們有以下幾個關鍵的區別: 2. 作用范圍和功能 ObjectAnimator&#xff1a…

3d GIS數據來源與編輯工具

1、衛星遙感 2、航空攝影測量 3、地面實測技術 全站儀 3維掃描 3D GIS數據制作全流程詳解 一、數據采集:多源數據獲取 3D GIS數據的制作需從多維度采集地理空間信息,以下是主要采集方式及適用場景: (一)遙感與航測…

實驗設計與分析(第6版,Montgomery)第4章隨機化區組,拉丁方, 及有關設計4.5節思考題4.26~4.27 R語言解題

本文是實驗設計與分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅玨生譯) 第章隨機化區組&#xff0c;拉丁方&#xff0c; 及有關設計4.5節思考題4.26~4.27 R語言解題。主要涉及方差分析&#xff0c;正交拉丁方。 batch <- c(rep("batch1",5), rep(…

linux創建虛擬網卡和配置多ip

1.展示當前網卡信息列表&#xff1a; linux上&#xff1a; ip a ifconfigwindows上&#xff1a; ipconfig 2.創建虛擬網卡對&#xff1a; sudo ip link add name veth0 type veth peer name veth1 在 ip link add 命令中&#xff0c;type 參數可以指定多種虛擬網絡設備類型&…

分布式項目保證消息冪等性的常見策略

Hello&#xff0c;大家好&#xff0c;我是灰小猿&#xff01; 在分布式系統中&#xff0c;由于各個服務之間獨立部署&#xff0c;各個服務之間依靠遠程調用完成通信&#xff0c;再加上面對用戶重復點擊時的重復請求等情況&#xff0c;所以如何保證消息消費的冪等性是在分布式或…

微信小程序(uniapp)對接騰訊云IM

UniApp 對接騰訊云 IM&#xff08;即時通訊&#xff09;完整指南 一、項目背景與需求分析 隨著社交場景的普及&#xff0c;即時通訊功能已成為移動應用的標配。騰訊云 IM&#xff08;Tencent IM&#xff0c;即 TIM&#xff09;提供穩定可靠的即時通訊服務&#xff0c;支持單聊…

Portainer安裝指南:多節點監控的docker管理面板-家庭云計算專家

背景 Portainer 是一個輕量級且功能強大的容器管理面板&#xff0c;專為 Docker 和 Kubernetes 環境設計。它通過直觀的 Web 界面簡化了容器的部署、管理和監控&#xff0c;即使是非技術用戶也能輕松上手。Portainer 支持多節點管理&#xff0c;允許用戶從一個中央控制臺管理多…

[Redis] Redis命令在Pycharm中的使用

初次學習&#xff0c;如有錯誤還請指正 目錄 String命令 Hash命令 List命令 set命令 SortedSet命令 連接pycharm的過程見&#xff1a;[Redis] 在Linux中安裝Redis并連接桌面客戶端或Pycharm-CSDN博客 redis命令的使用見&#xff1a;[Redis] Redis命令&#xff08;1&#xf…

計算機網絡:物理層

目錄 一、物理層的基本概念 二、物理層下面的傳輸媒體 2.1 導引型傳輸媒體 2.1.1 同軸電纜 2.1.2 雙絞線 2.1.3 光纖 2.1.4 電力線 2.2 非導引型傳輸媒體 2.2.1 無線電波 2.2.2 微波 2.2.3 紅外線 2.2.4 可見光 三、傳輸方式 3.1 串行與并行 3.2 同步與異步 3.…

構建系統maven

1 前言 說真的&#xff0c;我是真的不想看構建了&#xff0c;因為真的太多了。又多又亂。Maven、Gradle、Make、CMake、Meson、Ninja&#xff0c;Android BP。。。感覺學不完&#xff0c;根本學不完。。。 但是沒辦法最近又要用一下Maven&#xff0c;所以咬著牙再簡單整理一下…

UE5藍圖暴露變量,在游戲運行時修改變量實時變化、看向目標跟隨目標Find Look at Rotation、修改玩家自身彈簧臂

UE5藍圖中暴露變量&#xff0c;類似Unity中public一個變量&#xff0c;在游戲運行時修改變量實時變化 1&#xff0c;添加變量 2&#xff0c;設置變量的值 3&#xff0c;點開小眼睛&#xff0c;此變量顯示在編輯器中&#xff0c;可以運行時修改 看向目標跟隨目標Find Look at R…

proteus美觀與偏好設置

本文主要講&#xff1a; 1 快捷鍵修改&#xff08;復制&#xff0c;粘貼&#xff0c;原件旋轉&#xff09; 2 背景顏色替換 3 模塊分區 一 快捷鍵的設置 設置復制粘貼和旋轉三個 這里只是強調一下要分配 二 背景顏色 原來的背景顏色&#xff1a; 之后的背景顏色&#xff1a;…

Arm處理器調試采用jlink硬件調試器的命令使用大全

arm處理器分為cortex-a&#xff0c;cortex-r&#xff0c;cortex-m等3個內核系列&#xff0c;其中m系列一般是單片機&#xff0c;例如stm32等&#xff0c;工控用得挺多。a系列一般是消費娛樂產品等使用較多&#xff0c;例如手機處理器。r系列是高端實時類型處理器&#xff0c;價…

如何將圖像插入 PDF:最佳工具比較

無論您是編輯營銷材料、寫報告還是改寫原來的PDF文件&#xff0c;將圖像插入 PDF 都至關重要。幸運的是&#xff0c;有多種在線和離線工具可以簡化此任務。在本文中&#xff0c;我們將比較一些常用的 PDF 添加圖像工具&#xff0c;并根據您的使用場景推薦最佳解決方案&#xff…

4、獲取樹莓派溫度

打開終端&#xff0c;使用指令查看CPU溫度&#xff0c;依次輸入以下指令&#xff1a; 1.進入操作目錄 cd /sys/class/thermal/thermal_zone0 2.查看溫度 cat temp 樹莓派的返回值 51540 返回值除以1000為當前CPU溫度值。即當前溫度為51攝氏度。

Leetcode 269. 火星詞典

1.題目基本信息 1.1.題目描述 現有一種使用英語字母的外星文語言&#xff0c;這門語言的字母順序與英語順序不同。 給定一個字符串列表 words &#xff0c;作為這門語言的詞典&#xff0c;words 中的字符串已經 按這門新語言的字母順序進行了排序 。 請你根據該詞典還原出此…

使用vscode進行c/c++開發的時候,輸出報錯亂碼、cpp文件本身亂碼的問題解決

使用vscode進行c/c開發的時候&#xff0c;輸出報錯亂碼、cpp文件本身亂碼的問題解決 問題描述解決方案問題1的解決方案問題2解決方案 問題描述 本篇文章解決兩個問題&#xff1a; 1.當cpp文件出現錯誤的時候&#xff0c;編譯時報錯&#xff0c;但是報錯內容缺是亂碼&#xff0…

現代數據湖架構全景解析:存儲、表格式、計算引擎與元數據服務的協同生態

本文全面剖析現代數據湖架構的核心組件,深入探討對象存儲(OSS/S3)、表格式(Iceberg/Hudi/Delta Lake)、計算引擎(Spark/Flink/Presto)及元數據服務(HMS/Amoro)的協作關系,并提供企業級選型指南。 一、數據湖架構演進與核心價值 數據湖架構演進歷程 現代數據湖核心價…