当前位置: 首页 > wzjs >正文

cms网站代理软文营销

cms网站代理,软文营销,检查wordpress主题,企业网站开发 流程版权归作者所有,如有转发,请注明文章出处:https://cyrus-studio.github.io/blog/ 前言 NDK 编译 so 默认情况下,所有 public 函数 都会导出,通过 IDA、GHIDRA 可以看到函数名 但除了必须导出的 JNI 函数外&#xff0c…

版权归作者所有,如有转发,请注明文章出处:https://cyrus-studio.github.io/blog/

前言

NDK 编译 so 默认情况下,所有 public 函数 都会导出,通过 IDA、GHIDRA 可以看到函数名

word/media/image1.png

但除了必须导出的 JNI 函数外,其余 C/C++ 函数符号不导出其实也完全没影响,编译器/链接器内部可以调用,运行时照样可以正常执行。

必须导出的 JNI 函数

函数名是否必须导出说明
JNI_OnLoad✅ 是(总是)系统通过 dlsym() 查找,初始化用
Java_…✅ 是(如果用静态注册)Java 层方法通过名称匹配
JNI_OnUnload❌ 否(可选)卸载时调用,不导出也不会出错
JNI_OnLoad_LibName(非标准)❌ 否(特殊系统扩展)Android 未使用
JNI_GetCreatedJavaVMs、JNI_CreateJavaVM❌ 否仅在 native 启动 JVM 时使用(一般用不到)

使用 linker version script 精细控制导出

Linker Version Script 是 GNU 链接器(ld)提供的一种机制,用来控制 .so 或 .a 文件中哪些符号可以导出、哪些必须隐藏。

创建 hide.map 文件(仅导出所有 JNI_ 和 Java_ 开头的 JNI 方法)

{global:JNI_*;Java_*;local:*;
};

解释

  • global: 表示这些符号会被导出,可供外部(如 ART)通过 dlsym() 使用。

  • Java_* 会匹配所有以 Java_ 开头的方法 —— 即静态注册 JNI 方法。

  • local: *; 表示其余全部符号(如内部 C 函数、C++ mangled 符号、加密算法、字符串处理等)一律隐藏,无法通过 IDA 等工具直接查看函数名。

在你的 CMakeLists.txt 中这样写:

# 抹除符号
set_target_properties(native-lib PROPERTIES LINK_FLAGS "-Wl,--version-script=${CMAKE_SOURCE_DIR}/hide.map")

参考:https://android-docs.cn/ndk/guides/symbol-visibility

测试

重新编译运行,使用 IDA Pro 打开 so ,可以看到只导出了 JNI 相关函数

word/media/image2.png

只控制导出符号,不影响内部调用,程序运行时不会出错。

word/media/image3.png

除了增加逆向难度,同时还能减少 so 文件的体积

word/media/image4.png

动态注册 JNI 方法,JNI 方法反跟踪

Android 的 ART 虚拟机会用 dlsym() 查找你导出的 JNI 方法(如Java_com_example_native_NativeUtils_secretMethod),所以这些你不能隐藏,否则会导致运行时崩溃。

如果你用 RegisterNatives 动态注册 JNI 方法,就可以完全避免导出 Java_com_xxx 的方法名:

#include <jni.h>// 定义方法签名
static JNINativeMethod methods[] = {{"secretMethod", "()V", (void *)secretMethod},
};// JNI_OnLoad 动态注册方法
jint JNI_OnLoad(JavaVM* vm, void* reserved) {JNIEnv* env = nullptr;vm->GetEnv((void**)&env, JNI_VERSION_1_6);jclass clazz = env->FindClass("com/example/native/NativeUtils");env->RegisterNatives(clazz, methods, sizeof(methods)/sizeof(methods[0]));return JNI_VERSION_1_6;
}

函数名字可以自定义:

void secretMethod(JNIEnv *env, jobject obj) {// your native code
}

此时 .so 中不需要导出 Java_com_example_xxx 符号,IDA 也就看不到!

完整源码

开源地址:https://github.com/CYRUS-STUDIO/AndroidExample

相关文章:

  • 移植 OLLVM 到 LLVM 18,C&C++代码混淆

  • 移植 OLLVM 到 Android NDK,Android Studio 中使用 OLLVM

  • OLLVM 增加 C&C++ 字符串加密功能

http://www.dtcms.com/wzjs/16797.html

相关文章:

  • 网站建设开票分类编码南京百度推广
  • 视频直播nba的网站打开网站搜索
  • 青岛网站建设 大公司网络推广招聘
  • 电影网站权重怎么做优化营商环境个人心得体会
  • 烟台建站价格制作企业网站
  • 买了域名之后如何做网站长沙关键词排名首页
  • 网站开发哈尔滨网站开发公司全网营销系统1700元真实吗
  • 网站开发费用周期百度推广开户免费
  • 自己做网站微商成都网站seo排名优化
  • 哪个网站的地图可以做分析图竞价推广课程
  • wordpress 主题 psd百度快照优化排名推广怎么做
  • 廊坊自助建站设计乐天seo视频教程
  • 做视频网站服务器友情链接如何添加
  • 事业单位网站备案广州品牌营销服务
  • qq怎么做自己的网站产品推广怎么做
  • 做网站发房源综合语录nba最新交易动态
  • 怎样做招聘网站分析网站建网站建设网站
  • 网站制作公司哪家专业微信营销案例
  • 免费com网站域名注册优化关键词排名
  • 可以先做网站后备案吗万网app下载
  • 建站快车优势青岛网站seo服务
  • 网站建设打造可以搜索任何网站的浏览器
  • 外贸自己做网站淘宝流量助手平台
  • 成都网站建设优化搜索引擎优化中的步骤包括
  • 黄山旅游攻略景点必去常州seo外包公司
  • 商洛市住户和城乡建设局网站信息价上优化seo
  • 网页设计与网站建设从入门到精通关键词优化怎么优化
  • 保定哪家做网站专业搜索引擎优化的内容
  • 聊城手机网站建设软件seo搜索铺文章
  • 做网站要下载的软件湖北seo