经常看到有人说部分 apk 可以绕过 xposed hook 的接口,
但是非 root 权限 安卓根本没有提供 C、C++的操作系统资源 API 啊,
那些绕过 xposed 模块 xprivacy 限制读取了短信等等,是否利用了系统漏洞做的呢?
有没人研究过这个问题
1
honeycomb 2018-02-13 11:01:21 +08:00 via Android
如果这个 c++ api 最后绕了一圈还是回到 java 层的话是绕不过去的
|
3
codehz 2018-02-13 11:28:40 +08:00 via Android
不是可以直接走 binder 相关获取信息么,据我所知,还没有试图影响 binder 的
|
4
honeycomb 2018-02-13 12:38:28 +08:00
|
5
nosugar OP @codehz
@honeycomb https://stackoverflow.com/a/19356010/8356718 ``` #include <cutils/properties.h> ``` 这个确实无解,安卓居然有库支持 C 获取系统变量 https://android.googlesource.com/platform/system/core/+/master/libcutils/include/cutils/ |
6
funCoder 2018-02-13 14:12:10 +08:00
@nosugar #5 现在一般是往 Xposed Module 中集成 Cydia Substrate,Java Hook 和 Native Hook 都能做。像 __system_property_get 这种函数也是能 hook 的。
|
7
nosugar OP @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 |
8
zj299792458 2018-02-13 17:07:01 +08:00 via iPhone
安卓的 C 接口和 Linnux 有什么不一样吗……
|
9
codehz 2018-02-13 17:13:16 +08:00 via Android
@nosugar 其实 hook native 层没啥特别的,我以前还 hook 文件相关的 libc 函数以实现安卓分应用存储重定向呢。。。
|
10
iceheart 2018-02-13 17:53:59 +08:00 via Android
写个 jni,静态链接所有依赖的包
|
13
cyspy 2018-02-15 07:49:39 +08:00 via Android
美团的技术博客前几天说过这个问题
|
14
deadEgg 2018-02-15 12:45:12 +08:00
android 的 c 接口还有人做了 boost 扩展
没有对系统资源的 api。 |