码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • mac环境下搭建frida环境并连接网易mumu模拟器


    一. frida概述

    frida是基于Hook的动态分析工具。是一款基于 python+javascript 的 hook 框架,核心是用C编写的,可运行在 android、ios、linux、win等各个平台,主要使用的动态二进制插桩技术。

    官网: https://www.frida.re/

    文档: https://www.frida.re/docs/android/

    安卓相关文件: https://github.com/frida/frida/releases

    关于frda学习路线了,只需要了解两方面的内容:
    1)主控端和目标进程的交互(message)
    2)Python接口和js接口(查文档)

    frida框架分为两部分:
    1)一部分是运行在系统上的交互工具frida CLI。
    2)另一部分是运行在目标机器上的代码注入工具 frida-serve。

    二. mac下环境搭建

    2.1 安装adb工具

    参考:DB各种操作指令详解大汇总

    2.2 安装frida

    pc端安装frida:

    Frida提供了四个工具,frida-trace,frida-ps,frida,frida-discover,这些工具都位于python的Scripts路径下。

    pip3 install frida
    
    pip3 install frida-tools==5.3.0
    
    #安装完成后可以查看一下版本信息
    frida --version
    
    #目前测试最好用的版本,坑少
    frida              12.11.18
    frida-tools        5.3.0
    frida-server       12.8.10
     
     
    frida              12.7.26
    frida-tools        5.3.0
    frida-server       12.8.10
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    手机端安装frida: https://github.com/frida/frida/releases
    下载电脑端对应版本的frida-server,如果没记住版本可以在终端中输入 frida --version 命令查看。

    Android为例,根据手机类型下载对应架构。

    adb shell 
    getprop ro.product.cpu.abi  # 输出:arm64-v8a,
    
    • 1
    • 2

    根据cpu版本去下载相应frida-server,手机是arm64-v8a的,找到相应的服务器server: frida-server-15.0.8-android-arm64.xz,下载,解压,放进手机,进行端口转发,运行frida-server,指令如下:

    # 放入手机
    adb push frida-server-15.0.8-android-arm64.xz /data/local/tmp
    
    # 端口转发
    adb forward tcp:27042 tcp:27042
    adb forward tcp:27043 tcp:27043
    
    # 运行frida
    adb shell 
    walleye:/ $ su
    walleye:/ # cd /data/local/tmp
    walleye:/ # chmod 777 frida-server-15.0.8-android-arm64.xz
    walleye:/ # ./frida-server-15.0.8-android-arm64.xz
    walleye:/ #
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    如果运行不了,关闭liunx的SELinux: echo 0 > /sys/fs/selinux/enforce。

    另打开一个cmd,输入:frida-ps -U,查看frida-server64是否运行成功。

    2.3 连接网易mumu模拟器

    打开终端,输入以下命令即可:

    adb connect 127.0.0.1:7555 # windows
    
    adb connect 127.0.0.1:5555 # mac
    
    • 1
    • 2
    • 3

    网易MuMu模拟器的配置文件在安装目录下emulator\nemu\vms\myandrovm_vbox86\myandrovm_vbox86.nemu文件中

    配置文件中的ADB_PORT与上面的127.0.0.1:7555相对应。

    2.4 出现的问题

    出现下面问题,则手机需要root。

    adb shell
    walleye:/ $ su
    /system/bin/sh: su: inaccessible or not found
    
    • 1
    • 2
    • 3
  • 相关阅读:
    Monaco Editor教程(十二):使用Marker来增加分词注释,标记,优化编辑器交互体验
    java利用EasyExcel实现导入功能,并返回错误信息的所属行列
    Python实用模块之argparse
    YoloV5实时推理最短的代码
    html5里引用vue.js,实现自定义组件,子父组件相互传参
    浅谈链游的未来:可定制性、身份和社交层
    人工智能的发展现状,AI将如何改变IT行业,哪些职业将最先失业
    juc面试题总结
    Apollo planning之PathBoundsDecider
    手工实现一个字符串内容替换方法来替换replace
  • 原文地址:https://blog.csdn.net/cui_yonghua/article/details/126714702
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号