/Android_Inline_Hook

Build an so file to automatically do the android_native_hook work. Supports thumb-2/arm32 and ARM64 ! With this, tools like Xposed can do android native hook.

Primary LanguageC

Android Inline Hook

This project make an Android .so file that can automatically do some native hook works.

It mainly use Android Inline Hook, not PLT Hook.

If you can read Chinese or wanna see more picture, I've wrote some articles about this repo and the first one is the main article. I highly recommend you to read the articles before reading the code. These article will save you a lot of time, I promise.

  1. Android Inline Hook Practice
  2. Opcode Fix In Android Inline Hook
  3. An Introduction to Android Native Hook
  4. Android Inline Hook ARM64 Practice

Articles in English

I've received several e-mails and all the questions in them have been written in the Chinese articles. So i think it's necessary translate some part of the articles in English. I will try my best to tanslate more part and the parts metioned by the questions in issue will have high priority.

  1. Android Inline Hook Practice EN

Features

  1. No ptrace -- So the anti-debug tech won't affect on this tool.
  2. Auto run -- Just use Xposed or other tools to load it into the memory and it will do the native hook work.
  3. Pure inline hook -- No other imprint left so it's hard to anti.
  4. Flexible -- Fine docs for users to understand the code and change it on your own perpose.
  5. Active support -- Brand new so I'm still keen on fix the bugs and arm32/thumb-2/arm64 has been finished one by one.

How To Use

The only thing you have to change is the code in InlineHook.cpp.

You can name the __attribute__((constructor)) ModifyIBored() function at your will and change the follow arg in it:

  1. pModuleBaseAddr is the address of your target so.
  2. target_offset is the offset of your hook point in the target so.
  3. is_target_thumb shows the hook point's CPU mode. You can know this information in the work of reversing before the hook work.

EvilHookStubFunctionForIBored function is the thing you really wanna do when the hook works. You can name at your will, but keep the arg (pt_regs *regs). It brings you the power to control the registers, like set r0 to 0x333 : regs->uregs[0]=0x333;.

After you finish the args above, just ndk-build and you will get your .so file.

ARM32 Design

The ARM32 has code fix too, I just didn't show in this picture.

Thumb-2 Design

Example

I've make some examples in other repo, it includes code and the target APK file.

  1. thumb-2 example
  2. arm32 example

ARM64

ARM64 has been finished ! I put it in another Android Inline Hook ARM64 to keep clean.

Contact

I believe that this project still has some problems. If you find some bugs or have some problems, you can send e-mail to gtoad1994@aliyun.com. I wish we can fix it together!

Reference

Game Security Lab of Tencent

Ele7enxxh's Blog