当前位置:   article > 正文

安卓逆向——Frida安装和使用_frida12.11.6

frida12.11.6

Frida 安装和使用

1.  简介

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

2. Frida安装  官方地址 ,github地址

2.1 PC端:

  1. # 首先需要python环境,安装python
  2. install Python 3.x
  3. # 安装 frida库
  4. pip install frida
  5. # 安装frida-tools工具
  6. pip install frida-tools
  7. #目前测试最好用的版本,坑少
  8. frida 12.11.18
  9. frida-tools 5.3.0
  10. frida-server 12.8.10
  11. frida 12.7.26
  12. frida-tools 5.3.0
  13. frida-server 12.8.10

         安装测试, 命令行执行 frida-ps,输出系统运行的所有进程及pid

2.2 移动端

  1. Android :
  2. 先root, 再配置 frida-server (下载并push到/data/tmp/local,
  3. 以root权限执行, 下载地址 https://github.com/frida/frida/releases)
  4. iOS :
  5. 先 jailbreak,再从cydia下载frida插件。
  6. 果没法root或越狱,可简单的修改应用,在应用初始化时,主动加载frida组件,相当于进程内部hook。
  7. 详见:https://frida.re/docs/gadget/ (强烈建议设备root或越狱)

         安装测试, 命令行执行 frida-ps -U,输出系统运行的所有进程及pid

3. 使用案例

3.1  我测试使用 夜神模拟器apk文件adb工具frida-server

  注意 注意 注意 !!!  夜神模拟器的adb版本和adb工具的版本必须一致才能检测到,下面是的手机模拟器 版本

     

打开 手机模拟器 后,可以用 电脑的 命令行,输入指令检测一下设备,检测到 一台设备就没问题了

连接后,查看手机型号,下载系统对应版本的 ,我上传的文件都是 版本对应好的,可以直接下载

  1. # 查看手机型号
  2. adb shell getprop ro.product.cpu.abi

   

将解压之后的文件push 到设备中,指定到 /data/local/tmp 

  1. # 把frida-server 放到 安卓的/data/local/tmp/目录
  2. adb push frida-server /data/local/tmp/

运行Android 设备中的 frida-server

  1. # 进入 手机命令
  2. adb shell
  3. # 超级管理
  4. su
  5. # 进入 frida-server 目录
  6. cd /data/local/tmp
  7. # 修改 文件 权限
  8. chmod 755 frida-server
  9. # 运行文件
  10. ./frida-server

执行完毕后为运行状态。

保留此窗口 shell,以保证服务运行,关闭该shell 或者停止ctrl+c 则服务关闭。接下来的操作可另起shell 或该步骤命令另起 shell 执行。

进行端口转发监听

  1. 进行端口转发监听
  2. adb forward tcp:27042 tcp:27042
  3. adb forward tcp:27043 tcp:27043

检查是否成功

执行 frida-ps -U 命令成功输出进程列表,如下所示

执行frida -U -f com.xxx.xxx 进行连接,选择一个进程,等待一段时间则进入该应用    

  1. # 命令成功输出进程列表
  2. frida-ps -U
  3. frida-ps -R 都可以
  4. # 进行连接,选择一个进程
  5. frida -U -f com.xxx.xxx 

       

到这里为止 手机环境 已完成

 

PC电脑  

     反编译 apk 

  1. # 反编译
  2. apktool d xxx.apk

反编译之后生成 文件夹,打开 xml 文件

 

jadx 反编译, 找逻辑

分析完了,用python来加载脚本到指定进程

  1. # -*- coding: utf-8 -*-
  2. import frida
  3. import sys
  4. def on_message(message, data):
  5. if message['type'] == 'send':
  6. print("*****[frida hook]***** : {0}".format(message['payload']))
  7. else:
  8. print("*****[frida hook]***** : " + str(message))
  9. jscode = """
  10. Java.perform(function () {
  11. var MainActivity = Java.use('com.yaotong.crackme.MainActivity');
  12. MainActivity.securityCheck.implementation = function(str){
  13. return true;
  14. };
  15. });
  16. """
  17. process = frida.get_usb_device(-1).attach('com.yaotong.crackme')
  18. script = process.create_script(jscode)
  19. script.on('message', on_message)
  20. print('[*] Running CTF')
  21. script.load()
  22. sys.stdin.read()

执行 代码,再次 打开软件,任意输入或不输入 都可以进去,因为 hook植入代码 把 securityCheck 的改写了,就不会检测了

                                           

 

版本很重要,流程过程很简单,环境很折腾人。

 

参考:https://www.cnblogs.com/mysticbinary/p/12012935.html

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/59759
推荐阅读
相关标签
  

闽ICP备14008679号