经过一番认真的谷歌潜伏后,我没有发现任何与此问题相关的有用信息,所以我会在这里问它。
我有一个用 C# 编写的程序,它将一个 DLL 注入另一个进程,相当简单。它使用 [DllImport] 从 kernel32.dll 调用 CreateRemoteThread 和 LoadLibrary。
我的 DLL 一旦加载然后等待来自 C# 程序的身份验证,由于安全原因,我无法使用套接字传输这些数据。所以我让我的 DLL 导出一个函数,该函数计划从 C# 程序中调用,并带有身份验证数据。
导出的函数有两个参数,如下:
extern "C" __declspec(dllexport) void DoStuff( const char* ccString1, const char* ccString2 ){
// Do stuff
}
由于 DLL 与 C# 程序不在同一地址空间中,因此我无法使用 [DllImport] 获取和调用导出的函数。
我的第二个想法是使用 CreateRemoteThread 来调用函数,虽然它只能传递 1 个参数而我需要两个,这也很困难,因为我需要调用 GetProcAddress 的返回,我不能简单地调用直接导出函数。
那么,我将如何实现这一目标?
谢谢