码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 安卓逆向 - Frida反调试绕过


    本文仅供学习交流,只提供关键思路不会给出完整代码,严禁用于非法用途,谢绝转载,若有侵权请联系我删除!

    本文案例 app:5Lqs5LicYXBwMTEuMy4y

    一、引言:

    Frida是非常优秀的一款 Hook框架,人红是非多,市面上很多app都有相应的检测方案。本人在分析某东app时,android端启动frida-server后,打开app直接卡在首页。

    尝试hook: 执行 frida -U -l Hook.js -f  com.jingdong.app.mall

    报 Process terminated退出

    二、常见检测:

    1、检测文件名

    2、检测端口

    3、双进程保护

    4、检测D-Bus

    5、检测/proc/pid/maps映射文件

    6、检测/proc/pid/task/tip/status

    7、检测/data/local/tmp目录

    三、绕过

    针对以上的检测方式,我们可以尝试改文件名,改端口,spawn启动,隐藏frida特征等方式来绕过检测。

    1、使用Frida的魔改版本 Hluda来隐藏Frida特征,其介绍:跟随 FRIDA 上游自动修补程序,并为 Android 构建反检测版本的 frida-server。使用方式跟官方Frida没有区别。

    github地址:https://github.com/hzzheyang/strongR-frida-android/

    2、修改端口

    本人使用的是模拟器,官方Frida默认端口是27042,现在我们来修改启动端口,android端使用命令启动hluda:

     ./hlu-server_x8664 -l 0.0.0.0:8080

    本地映射端口:

    adb forward tcp:8080 tcp:8080

    启动 js hook脚本指定端口:

    frida -H 127.0.0.1:8080 -f com.jingdong.app.mall -l Hook.js

    使用的hook脚本示例:

    1. function hook1() {
    2. var URL = Java.use('java.net.URL');
    3. console.log("进入hook1")
    4. URL.$init.overload('java.lang.String').implementation = function (a) {
    5. console.log('加密前:' + a)
    6. showStacks()
    7. this.$init(a)
    8. }
    9. }
    10. function showStacks() {
    11. Java.perform(function () { console.log(Java.use("android.util.Log").getStackTraceString(Java.use("java.lang.Exception").$new()));
    12. });
    13. }

     成功打印出堆栈信息,app也是正常启动,说明我们已经成功绕过检测,收工!

  • 相关阅读:
    【JavaScript 算法】链表操作:从基础到进阶
    花生壳配置TCP服务器
    Java-GUI编程之处理位图
    【LeetCode刷题(数据结构)】:给定一个链表 每个节点包含一个额外增加的随机指针 该指针可以指向链表中的任何节点或空节点 要求返回这个链表的深度拷贝
    不吹不黑,网络安全工程师年薪30万是真的吗?
    实现阿里云模型服务灵积 DashScope 的 Semantic Kernel Connector
    VUE3 + Django 接口请求每次都产生新的session_id,应该如何解决?
    thinkphp6-简简单单地开发接口
    yolov7改进优化之蒸馏(二)
    【Stable Diffusion教程】AI绘画工具SD如何安装使用?三种方法带你轻松上手!(附安装包和云端部署教程)
  • 原文地址:https://blog.csdn.net/weixin_42840266/article/details/132628782
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号