Delphi中的COM方法偏移

前端之家收集整理的这篇文章主要介绍了Delphi中的COM方法偏移前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在Delphi中,如何找到COM方法的地址?
我可以硬编码偏移量
//0 is the offset of the QueryInterface method
p := TPonterArray(pointer(SomeInterface)^)[0];

但我更喜欢使用符号名称.以下显然不起作用:

var M : TMethod;
...
M := TMethod(SomeInterface.QueryInterface);

谢谢!

解决方法

您可以使用vmtoffset汇编程序指令获取接口方法相对于接口方法表开头的字节偏移量.看一下System.pas中_IntfCast的实现,例如:
call dword ptr [eax] + vmtoffset IInterface.QueryInterface
...
call dword ptr [eax] + vmtoffset IInterface._Release

第一个表达式加0;第二,8.

但是,您无法对这些表达式进行参数化.它们是编译时常量,因此您无法在运行时选择所需的方法.您需要提前表示所有可能的方法名称.

你真正需要挂钩的是QueryInterface.完成后,您可以返回所需的任何代理对象,可以拦截对所有其他方法调用.

原文链接:https://www.f2er.com/delphi/103189.html

猜你在找的Delphi相关文章