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

.NET外挂系列:2. 了解强大的 harmony 注解特性

一:背景

1. 讲故事

上一篇我们简单的聊了下harmony外挂的基本玩法,让大家宏观上感受到了外挂在 .NET高级调试 领域的威力,这一篇我们从 注解特性 这个角度继续展开。

二:harmony 注解特性

1. HarmonyPatch 解读

在harmony支持的众多特性中,HarmonyPatch算是最基础的一个,注解特性简单来说就是harmony目标类 沟通的桥梁,为了让沟通更加简洁,harmony 提供了 20 个重载,参考如下:


[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method | AttributeTargets.Delegate, AllowMultiple = true)]
public class HarmonyPatch : HarmonyAttribute
{public HarmonyPatch();public HarmonyPatch(Type declaringType);public HarmonyPatch(Type declaringType, Type[] argumentTypes);public HarmonyPatch(Type declaringType, string methodName);public HarmonyPatch(Type declaringType, string methodName, params Type[] argumentTypes);public HarmonyPatch(Type declaringType, string methodName, Type[] argumentTypes, ArgumentType[] argumentVariations);public HarmonyPatch(Type declaringType, MethodType methodType);public HarmonyPatch(Type declaringType, MethodType methodType, params Type[] argumentTypes);public HarmonyPatch(Type declaringType, MethodType methodType, Type[] argumentTypes, ArgumentType[] argumentVariations);public HarmonyPatch(Type declaringType, string methodName, MethodType methodType);public HarmonyPatch(string methodName);public HarmonyPatch(string methodName, params Type[] argumentTypes);public HarmonyPatch(string methodName, Type[] argumentTypes, ArgumentType[] argumentVariations);public HarmonyPatch(string methodName, MethodType methodType);public HarmonyPatch(MethodType methodType);public HarmonyPatch(MethodType methodType, params Type[] argumentTypes);public HarmonyPatch(MethodType methodType, Type[] argumentTypes, ArgumentType[] argumentVariations);public HarmonyPatch(Type[] argumentTypes);public HarmonyPatch(Type[] argumentTypes, ArgumentType[] argumentVariations);public HarmonyPatch(string typeName, string methodName, MethodType methodType = MethodType.Normal);
}

上面的20个重载方法都是从各种角度灵活定位到 目标方法,基本上能覆盖95%的场景,非常的强大,接下来我们使用这些特性优化上一篇的案例,一个洞察为什么突然的线程暴涨,参考代码如下:

internal class Program{static void Main(string[] args){// 创建 Harmony 实例var harmony = new Harmony("com.example.threadhook");// 应用补丁harmony.PatchAll();Task.Factory.StartNew(() => { Test(); });Console.ReadLine();}static void Test(){// 测试线程var thread = new Thread(() => Console.WriteLine("线程正在运行"));thread.Start();}}[HarmonyPatch(typeof(Thread), "Start", new Type[] { })]public class ThreadStartHook{// 前缀补丁 - 在原始方法执行前运行public static void Prefix(Thread __instance){Console.WriteLine("----------------------------");Console.WriteLine($"即将启动线程: {__instance.ManagedThreadId}");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}}

三:案例优化

1. 如何实现多Start监控

上面的例子只是对 无参Start 进行的监控,可能会漏掉那些 有参Start 的情况,所以保守起见新增一个监控,代码如下:

[HarmonyPatch(typeof(Thread), "Start", new Type[] { })]public class ThreadStartHook{// 前缀补丁 - 在原始方法执行前运行public static void Prefix(Thread __instance){Console.WriteLine("----------------------------");Console.WriteLine($"即将启动线程: {__instance.ManagedThreadId}");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}}[HarmonyPatch(typeof(Thread), "Start", new Type[] { typeof(object) })]public class ThreadStartWithParamHook{// 前缀补丁 - 在原始方法执行前运行public static void Prefix(Thread __instance){Console.WriteLine("----------------------------");Console.WriteLine($"即将启动线程: {__instance.ManagedThreadId}");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}}

为了对 Start(object) 监控,我新增了一个 ThreadStartWithParamHook 类,虽然可以实现,但代码显的有些凌乱和累赘,那如何优化呢?这时候就可以使用新的 HarmonyPrefix 特性以及利用 注解的层级特点 来解决问题,优化之后的代码如下:

[HarmonyPatch(typeof(Thread), "Start")]public class ThreadStartHook{[HarmonyPrefix][HarmonyPatch(new Type[] { })]public static void Start(Thread __instance){Console.WriteLine("----------------------------");Console.WriteLine($"即将启动线程: {__instance.ManagedThreadId}");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}[HarmonyPrefix][HarmonyPatch(new Type[] { typeof(object) })]public static void StartWithParam(Thread __instance){Console.WriteLine("----------------------------");Console.WriteLine($"即将启动线程: {__instance.ManagedThreadId}");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}}

大家可以对比下代码,是不是好很多,这里稍微解释下:

  1. 我们将 [HarmonyPatch(typeof(Thread), "Start", new Type[] { typeof(object) })] 拆成了 [HarmonyPatch(typeof(Thread), "Start")] + [HarmonyPatch(new Type[] { })] 的模式,这就是层次性。

  2. 由于 Prefix 是 harmony 默认的前缀方法,如果不想用这个方法名,就必须使用 HarmonyPrefix 标注到你自定义的方法名上。

到这里可能有些人要反驳我,如果我的 Start 有10个重载,是不是也要对应的写10个hook方法?这样搞的话还是太麻烦了,有没有更加简洁的方式? 我要告诉你的是,肯定是可以的,你所焦虑的事情别人早就考虑到了,答案就是 harmony 在底层开了一个口子,让你通过自定义代码返回要 patch 的方法,参考代码如下:

[HarmonyPatch]public class ThreadStartHook{//harmony 开的口子,返回要注入的方法。static IEnumerable<MethodBase> TargetMethods(){var methodlist = typeof(Thread).GetMethods().Where(method => method.Name.StartsWith("Start")).Cast<MethodBase>();return methodlist;}public static void Prefix(Thread __instance, MethodBase __originalMethod){var parameters = __originalMethod.GetParameters().Select(i => i.ParameterType.Name);Console.WriteLine("----------------------------");Console.WriteLine($"{__originalMethod.Name} ({string.Join(",", parameters)})");Console.WriteLine(Environment.StackTrace);Console.WriteLine("----------------------------");}}

代码中的 TargetMethods 方法就像一把利剑一样,批量的注入Start方法,你也可以根据你的需要灵活筛选,最后上一张图,

四:总结

通过不断的对 Thread.Start 方法进行注入优化,相信大家也感受到了harmony的异常强大,最后就是希望给训练营里的朋友一些思考和资料参考吧。

相关文章:

  • Adminer:一个基于Web的轻量级数据库管理工具
  • 游戏引擎学习第295天:堆叠房间用于Z层调试
  • 芯驰科技与安波福联合举办技术研讨会,深化智能汽车领域合作交流
  • 洛谷U536262 井底之“鸡”
  • 【Unity网络编程知识】Unity的 UnityWebRequest相关类学习
  • ThreadLocal作一个缓存工具类
  • 超小多模态视觉语言模型MiniMind-V 训练
  • OV7670连接STM32F407VET
  • Java迭代器知识点详解
  • 从编程助手到AI工程师:Trae插件Builder模式实战Excel合并工具开发
  • 在CentOS系统上部署GitLabRunner并配置CICD自动项目集成!
  • 《算法导论(第4版)》阅读笔记:p86-p90
  • Windows逆向工程提升之二进制分析工具:HEX查看与对比技术
  • 自制操作系统day4(c指针)(指针和数组)(CLI和STI)(EFLAGS)
  • 力扣刷题Day 50:接雨水(42)
  • 你的it管理员已经限制对此应用一些区域的访问
  • MySQL进阶篇-InnoDB引擎(超细)
  • MySQL死锁:面试通关“三部曲”心法
  • Linux的权限问题
  • 【SPIN】PROMELA语言编程入门同步机制(SPIN学习系列--4)
  • 66岁华仁世纪集团有限公司创始人、董事长梁福东逝世
  • 永久基本农田竟沦为垃圾场,湖南湘潭回应:全面启动专项整治
  • 优质文化资源下基层,上海各区优秀群文团队“文化走亲”
  • 广东进入“倒水模式”,珠江防总、珠江委已启动Ⅳ级应急响应
  • 意德首脑会谈,梅洛尼警告欧盟绿色政策面临“工业荒漠化”
  • 北方首场高温将进入鼎盛阶段,江南华南多地需警惕降雨叠加致灾