mirror of
https://github.com/HighCapable/YukiHookAPI.git
synced 2025-09-04 09:45:19 +08:00
e8e29928d9c8ed6df08d3f115c8088059a2b030a
Yuki Hook API
⛱️ An efficient Kotlin version of the Xposed Hook API.
What's this
- 这是一个使用 Kotlin 重新构建的高效 Xposed Hook API
- 名称取自 《ももくり》女主 栗原 雪(Yuki)
- 前身为 开发学习项目 中使用的 Innocent Xposed API,现在重新命名并开源
Function
- Xposed 模块开发
自动构建程序可以帮你快速创建一个 Xposed 模块,完全省去配置入口类和 xposed_init 文件。 - 轻量优雅
拥有一套强大、优雅和人性化的 Kotlin Lambda Hook API,可以帮你快速实现 Method、Constructor、Field 的查找以及 Hook。 - 高效调试
拥有丰富的调试日志功能,细到每个 Hook 方法的名称、所在类以及查找耗时,可进行快速调试和排错。 - 方便移植
原生支持 Xposed API 用法,并原生对接 Xposed API,拥有 Xposed API 的 Hook 框架都能快速对接 Yuki Hook API。 - 支持混淆
使用 Yuki Hook API 构建的 Xposed 模块原生支持 R8 压缩优化混淆,混淆不会破坏 Hook 入口点,R8 下无需任何其它配置。 - 快速上手
简单易用,不需要繁琐的配置,不需要十足的开发经验,搭建环境集成依赖即可立即开始使用。
Support
Hook Framework | ST | Describe |
---|---|---|
LSPosed | ✅ | 多场景下稳定使用 |
EdXposed | ☑ | 部分兼容 |
Pine | ⭕ | 可以使用 |
SandHook | ⭕ | 可以使用 |
Whale | ⭕ | 需要 xposed-hook-based-on-whale |
YAHFA | ❗ | 需要自行实现 Xposed API |
FastHook | ❗ | 需要自行实现 Xposed API |
Epic | ❗ | 需要自行对接 Dexposed |
TaiChi | ⭕ | 可以作为模块使用 |
Xposed | ❎ | 未测试,不再推荐使用 |
Advantage
以前,我们在构建 Xposed 模块的时候,首先需要在 assets
下创建 xposed_init
文件。
然后,将自己的入口类名手动填入文件中,使用 XposedHelper
去实现我们的 Hook 逻辑。
- 示例如下
class MainHook : IXposedHookLoadPackage {
override fun handleLoadPackage(lpparam: XC_LoadPackage.LoadPackageParam) {
if (lpparam.packageName == "com.android.browser")
XposedHelpers.findAndHookMethod(
Activity::class.java.name,
lpparam.classLoader,
"onCreate",
Bundle::class.java,
object : XC_MethodHook() {
override fun beforeHookedMethod(param: MethodHookParam?) {
// Your code here.
}
override fun afterHookedMethod(param: MethodHookParam?) {
// Your code here.
}
})
}
}
自 Kotlin
作为 Android 主要开发语言以来,这套 API 用起来确实已经不是很优雅了。
有没有什么 好用、轻量、优雅 的解决办法呢?
本着这样的想法,YukiHookAPI
诞生了。
现在,我们只需要编写少量的代码,一切时间开销和花费交给自动化处理。
- 示例如下
@InjectYukiHookWithXposed
class MainHook : YukiHookXposedInitProxy {
override fun onHook() = encase {
loadApp(name = "com.android.browser") {
ActivityClass.hook {
injectMember {
method {
name = "onCreate"
param(BundleClass)
}
beforeHook {
// Your code here.
}
afterHook {
// Your code here.
}
}
}
}
}
}
是的,你没有看错,仅仅就需要这几行代码,就一切安排妥当。
代码量少,逻辑清晰,借助高效强大的 YukiHookAPI
,你就可以实现一个非常简单的 Xposed 模块。
Get Started
- 你可以点击 快速开始,在
Gradle
中集成YukiHookAPI
并开始使用。 - 更多使用教程及 API 文档请 前往 Wiki 主页 进行查看。
Changelog
- 1.0
首个版本提交至 Maven。 - 1.0.1
RemedyPlan
增加onFind
功能;
整合并修改了部分反射 API 代码;
增加了type
中的java
类型;
修复忽略错误在控制台仍然输出的问题。
Donate
License
MIT License
Copyright (C) 2019-2022 HighCapable
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
版权所有 © 2019-2022 HighCapable
Description
⛱️ An efficient Hook API and Xposed Module solution built in Kotlin.
androidhook-apikotlinkotlin-androidkotlin-librarylibraryxposedxposed-frameworkxposed-modulexposedmodule
Readme
Apache-2.0
31 MiB
Languages
Kotlin
97.7%
TypeScript
1.9%
SCSS
0.4%