gpt4 book ai didi

c++ - (Dependency Walker) 缺少函数的显式类型

转载 作者:太空宇宙 更新时间:2023-11-04 14:01:41 27 4
gpt4 key购买 nike

提前为菜鸟的错误道歉。这是我的第一个问题。首先,一些背景:

我正在尝试使用 dependency walker 为程序创建一个模块,以在我没有 lib 或任何源代码的 .dll 中查找 C++ 函数。你也可以假设我得不到原开发者的支持。基本上,我检查了另一个访问它的文件,以查看使其工作所需的最少功能。这是输出的未修饰名称的示例:

void foo::bar::baz(float)
float foo::bar::qux(void)
foo::bar::bar(void)
class foo::bar & foo::bar::operator=(class foo::bar const &)

前两个函数显然接受 float 或 void 并返回 float 或 void。我使用类似的东西得到了类似的功能:

HINSTANCE THEDLL = LoadLibrary("C:\\dllFolder\\theDll.dll");
typedef float (*quxType)(void);
quxType qux = (quxType)GetProcAddress(THEDLL, "quxMangledName");

所以这些都不是问题。

现在,列表中的第三个看起来像另一个接受 void 的函数,但它没有明确的返回类型。这是否意味着我应该只为它使用隐式类型,它是无效的,还是不是一个真正的函数?如果不是,那是什么?

我不知道如何处理第四个。没有关联的 .h 文件是否可以处理?

我环顾四周,但找不到任何有关当函数看起来不像具有显式返回类型的普通函数时该怎么做的信息。尽管我使用的代码与我用来在类似的 .dll 中运行的函数基本相同,但当我尝试在此处使用函数 #2 时,我总是遇到访问冲突崩溃(我真的只需要函数 #2)。所以我猜测 .dll 需要更多信息或需要先初始化一些东西,这就是为什么我对列表中的其他内容感兴趣。

我意识到这是一个复杂的问题,所以可能不会有一个“正确答案”的解决方案来让它工作,但是如果我犯了任何明显的错误,或者是否有任何关于如何攻击问题(甚至是 dependency walker 的替代品),让我知道。

最佳答案

第三个是bar的默认构造函数。第4个是bar的复制赋值运算符。

我认为您需要先实例化该类,以便调用第二个方法。否则,将使用导致访问冲突的无效“this”调用该方法。

问题是你如何实例化它?如果你能在DLL中找到一个返回bar的工厂函数,你可以尝试使用它。

如果您没有看到工厂函数并且没有 lib 文件,您可以引用此处有关如何从 DLL 创建 lib 的答案:How to make a .lib file when have a .dll file and a header file

您还需要使用正确的成员顺序和类型为类创建头文件。这样您就不必使用 LoadLibrary 和 GetProcAddress,只需照常使用该类即可。

不过,您仍然可以在没有库和 header 的情况下使用 LoadLibrary 和 GetProcAddress,此博客展示了如何手动分配内存、调用构造函数、获取对象并传递该对象以调用方法:http://recxltd.blogspot.com/2012/02/working-with-c-dll-exports-without.html

关于c++ - (Dependency Walker) 缺少函数的显式类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19073715/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com