4

经过一番认真的谷歌潜伏后,我没有发现任何与此问题相关的有用信息,所以我会在这里问它。

我有一个用 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 的返回,我不能简单地调用直接导出函数。

那么,我将如何实现这一目标?

谢谢

4

2 回答 2

0

您可以使用非持久内存映射文件在应用程序和 DLL 之间交换数据。

于 2013-06-02T08:24:29.110 回答
0

[DllImport] 与 GetProcAddress 相同。C# 在第一次调用之前不会加载 DLL,因此 .NET 可以在调用 DLL 之前进行安全检查。


如果您根本不信任 DLL,那么最好将 de C# 程序一分为二。一个程序通过 Remoting/WCF/IPC 连接到第二个程序,第二个程序通过 DllImport 连接到 C DLL。当您不信任 C DLL 稳定性或内存分配时,通常使用此解决方案,因为无需重新启动主程序即可重新启动第二个程序(调用 de C DLL 的程序)。此模式的示例:一些 Windows 驱动程序(除了它们目前不使用 C#)。

于 2013-06-02T08:16:05.897 回答