CAPEC-661: Root/Jailbreak Detection Evasion via Debugging
CAPEC版本: 3.9
更新日期: 2023-01-24
攻击模式描述
An adversary inserts a debugger into the program entry point of a mobile application to modify the application binary, with the goal of evading Root/Jailbreak detection. Mobile device users often Root/Jailbreak their devices in order to gain administrative control over the mobile operating system and/or to install third-party mobile applications that are not provided by authorized application stores (e.g. Google Play Store and Apple App Store). Rooting/Jailbreaking a mobile device also provides users with access to system debuggers and disassemblers, which can be leveraged to exploit applications by dumping the application's memory at runtime in order to remove or bypass signature verification methods. This further allows the adversary to evade Root/Jailbreak detection mechanisms, which can result in execution of administrative commands, obtaining confidential data, impersonating legitimate users of the application, and more.
执行流程
步骤 1 Explore
[Identify application with attack potential] The adversary searches for and identifies a mobile application that could be exploited for malicious purposes (e.g. banking, voting, or medical applications).
- Search application stores for mobile applications worth exploiting
步骤 2 Experiment
[Debug the target application] The adversary inserts the debugger into the program entry point of the mobile application, after the application's signature has been identified, to dump its memory contents.
- Insert the debugger at the mobile application's program entry point, after the application's signature has been identified.
- Dump the memory region containing the now decrypted code from the address space of the binary.
步骤 3 Experiment
[Remove application signature verification methods] Remove signature verification methods from the decrypted code and resign the application with a self-signed certificate.
步骤 4 Exploit
[Execute the application and evade Root/Jailbreak detection methods] The application executes with the self-signed certificate, while believing it contains a trusted certificate. This now allows the adversary to evade Root/Jailbreak detection via code hooking or other methods.
- Optional: Hook code into the target application.
前提条件
- A debugger must be able to be inserted into the targeted application.
所需技能
所需资源
- The adversary must have a Rooted/Jailbroken mobile device with debugging capabilities.
后果影响
影响范围: Integrity Authorization
技术影响: Execute Unauthorized Commands
说明: Through Root/Jailbreak Detection Evasion via Debugging, the adversary compromises the integrity of the application.
影响范围: Confidentiality Access Control Authorization
技术影响: Gain Privileges
影响范围: Confidentiality Access Control
技术影响: Read Data
说明: An adversary may leverage Root/Jailbreak Detection Evasion via Debugging in order to obtain sensitive information.
缓解措施
Instantiate checks within the application code that ensures debuggers are not attached.
示例实例
An adversary targets an iOS banking application in an attempt to compromise sensitive user data. The adversary launches the application with the iOS debugger and sets a breakpoint at the program entry point, after the application's signature has been verified. Next, the adversary dumps the memory region that contains the decrypted code from the address space of the binary. The 'Restrict' flag is then stripped from the application and the adversary resigns the application with a self-signed certificate. The application is now executed without the 'Restrict' flag, while trusting the self-signed certificate to be legitimate. However, the adversary is now able to evaded Jailbreak detection via code hooking or other methods and can glean user credentials and/or transaction details.