日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

【Android 逆向】ART 脱壳 ( DexClassLoader 脱壳 | exec_utils.cc 中执行 Dex 编译为 Oat 文件的 Exec 和 ExecAndReturnC函数 )

發布時間:2025/6/17 Android 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Android 逆向】ART 脱壳 ( DexClassLoader 脱壳 | exec_utils.cc 中执行 Dex 编译为 Oat 文件的 Exec 和 ExecAndReturnC函数 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 前言
  • 一、exec_utils.cc#Exec 函數分析
  • 二、exec_utils.cc#ExecAndReturnCode 函數分析

前言



在上一篇博客 【Android 逆向】ART 脫殼 ( DexClassLoader 脫殼 | oat_file_assistant.cc 中涉及的 oat 文件生成流程 ) 中分析到 將 Dex 文件編譯為 Oat 文件 , 最終在 oat_file_assistant.cc#Dex2Oat 函數中 , 調用了 exec_utils.cc#Exec 函數 , 在該函數中執行最后的轉換操作 ;





一、exec_utils.cc#Exec 函數分析



在 exec_utils.cc#Exec 函數 中 , 調用了 ExecAndReturnCode 方法 ;

bool Exec(std::vector<std::string>& arg_vector, std::string* error_msg) {// ★ 核心跳轉int status = ExecAndReturnCode(arg_vector, error_msg);if (status != 0) {const std::string command_line(android::base::Join(arg_vector, ' '));*error_msg = StringPrintf("Failed execv(%s) because non-0 exit status",command_line.c_str());return false;}return true; }

源碼路徑 : http://aospxref.com/android-8.0.0_r36/xref/art/runtime/exec_utils.cc#Exec





二、exec_utils.cc#ExecAndReturnCode 函數分析



在該函數中 , 先 fork 一個進程 ,

pid_t pid = fork();

使用 execve 函數 , 執行 Dex 文件編譯為 Oat 文件操作 ;

execve(program, &args[0], envp);

exec_utils.cc#ExecAndReturnCode 函數源碼 :

int ExecAndReturnCode(std::vector<std::string>& arg_vector, std::string* error_msg) {const std::string command_line(android::base::Join(arg_vector, ' '));CHECK_GE(arg_vector.size(), 1U) << command_line;// 將參數轉換為字符指針。const char* program = arg_vector[0].c_str();std::vector<char*> args;for (size_t i = 0; i < arg_vector.size(); ++i) {const std::string& arg = arg_vector[i];char* arg_str = const_cast<char*>(arg.c_str());CHECK(arg_str != nullptr) << i;args.push_back(arg_str);}args.push_back(nullptr);// fork and execpid_t pid = fork();if (pid == 0) {// fork和exec之間不允許分配// 更改流程組,這樣我們就不會被ProcessManager收獲setpgid(0, 0);// (b/30160149): 保護子進程不受對LD_LIBRARY_路徑等的修改的影響。// 使用從創建運行時開始的環境快照。char** envp = (Runtime::Current() == nullptr) ? nullptr : Runtime::Current()->GetEnvSnapshot();if (envp == nullptr) {execv(program, &args[0]);} else {execve(program, &args[0], envp);}PLOG(ERROR) << "Failed to execve(" << command_line << ")";// _exit to avoid atexit handlers in child._exit(1);} else {if (pid == -1) {*error_msg = StringPrintf("Failed to execv(%s) because fork failed: %s",command_line.c_str(), strerror(errno));return -1;}// 等待子進程完成int status = -1;pid_t got_pid = TEMP_FAILURE_RETRY(waitpid(pid, &status, 0));if (got_pid != pid) {*error_msg = StringPrintf("Failed after fork for execv(%s) because waitpid failed: ""wanted %d, got %d: %s",command_line.c_str(), pid, got_pid, strerror(errno));return -1;}if (WIFEXITED(status)) {return WEXITSTATUS(status);}return -1;} }

源碼路徑 : /art/runtime/exec_utils.cc#ExecAndReturnCode

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的【Android 逆向】ART 脱壳 ( DexClassLoader 脱壳 | exec_utils.cc 中执行 Dex 编译为 Oat 文件的 Exec 和 ExecAndReturnC函数 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。