V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
nosugar
V2EX  ›  Android

C 语言、C++应该不能绕过 xposed hook 的接口吧

  •  
  •   nosugar · 2018-02-13 10:57:12 +08:00 · 13912 次点击
    这是一个创建于 2505 天前的主题,其中的信息可能已经有所发展或是发生改变。

    经常看到有人说部分 apk 可以绕过 xposed hook 的接口,
    但是非 root 权限 安卓根本没有提供 C、C++的操作系统资源 API 啊,
    那些绕过 xposed 模块 xprivacy 限制读取了短信等等,是否利用了系统漏洞做的呢?
    有没人研究过这个问题

    14 条回复    2018-02-15 12:45:12 +08:00
    honeycomb
        1
    honeycomb  
       2018-02-13 11:01:21 +08:00 via Android
    如果这个 c++ api 最后绕了一圈还是回到 java 层的话是绕不过去的
    nosugar
        2
    nosugar  
    OP
       2018-02-13 11:13:04 +08:00
    @honeycomb 确实是,目前除了 JNI,没发现 C 能通过别的途径读取系统信息,JNI 也是 java 发起的
    codehz
        3
    codehz  
       2018-02-13 11:28:40 +08:00 via Android
    不是可以直接走 binder 相关获取信息么,据我所知,还没有试图影响 binder 的
    honeycomb
        4
    honeycomb  
       2018-02-13 12:38:28 +08:00
    nosugar
        5
    nosugar  
    OP
       2018-02-13 13:59:00 +08:00
    @codehz
    @honeycomb

    https://stackoverflow.com/a/19356010/8356718

    ```
    #include <cutils/properties.h>
    ```
    这个确实无解,安卓居然有库支持 C 获取系统变量
    https://android.googlesource.com/platform/system/core/+/master/libcutils/include/cutils/
    funCoder
        6
    funCoder  
       2018-02-13 14:12:10 +08:00
    @nosugar #5 现在一般是往 Xposed Module 中集成 Cydia Substrate,Java Hook 和 Native Hook 都能做。像 __system_property_get 这种函数也是能 hook 的。
    nosugar
        7
    nosugar  
    OP
       2018-02-13 14:30:49 +08:00
    @funCoder
    public static native boolean doSomething(params...);
    这种 java 代码是可以 hook 的直接 return false,直接 hook C 代码?我觉得不行或者其难度极大类似 debug 汇编一样
    https://forum.xda-developers.com/xposed/xposed-hook-native-methods-t2817927
    zj299792458
        8
    zj299792458  
       2018-02-13 17:07:01 +08:00 via iPhone
    安卓的 C 接口和 Linnux 有什么不一样吗……
    codehz
        9
    codehz  
       2018-02-13 17:13:16 +08:00 via Android
    @nosugar 其实 hook native 层没啥特别的,我以前还 hook 文件相关的 libc 函数以实现安卓分应用存储重定向呢。。。
    iceheart
        10
    iceheart  
       2018-02-13 17:53:59 +08:00 via Android
    写个 jni,静态链接所有依赖的包
    codehz
        11
    codehz  
       2018-02-13 21:31:23 +08:00 via Android
    @iceheart 这个没法避免内核模块拦截系统调用(
    honeycomb
        12
    honeycomb  
       2018-02-14 18:36:39 +08:00 via Android
    @codehz 现在有个叫 rikka 的在做这件事
    cyspy
        13
    cyspy  
       2018-02-15 07:49:39 +08:00 via Android
    美团的技术博客前几天说过这个问题
    deadEgg
        14
    deadEgg  
       2018-02-15 12:45:12 +08:00
    android 的 c 接口还有人做了 boost 扩展

    没有对系统资源的 api。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1230 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 23:30 · PVG 07:30 · LAX 15:30 · JFK 18:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.