12

我知道有一个名为 Dll 的工具,但开发人员要价 1000 美元。我只需要转换一个库,一次,所以很难证明这个价格是合理的。

我试过 IMPLIB32.EXE,但我只是得到空的 .lib 文件。我怎样才能做到这一点?也许我可以编写一个简单的转换应用程序?

补充1:

Dll 通常是 stdcall 而不是 cdecl,并且是用较旧的 C 语言编写的,例如语言不是 C#、.NET 或 C++。我现在需要从 C++ 应用程序中调用它们。SQLite.dll 或 zlib.dll 就是一个例子。我无权访问这些 dll 的 .lib 文件。

补充2:

我为 VS2008 http://floodyberry.wordpress.com/2008/09/08/generating-dll-wrappers/重新编写了这段代码, 并在此处包含了可下载的示例 Dll 等: http ://www.transferbigfiles.com/Get .aspx?id=7d86fa0b-6ddc-4f6f-8d31-2c20824aae9a 这反过来会产生一个创建 Dll 的项目。当我尝试编译 Dll 时,出现链接器错误:AddShow.dll:致命错误 LNK1107:无效或损坏的文件:无法在 0x300 处读取此处描述: http: //list.isis.vanderbilt.edu/pipermail/udm-users /2006-March/000664.html 不确定如何继续。如此接近却又如此遥远

接下来我们转向这个方法

http://www.coderetard.com/2009/01/21/generate-a-lib-from-a-dll-with-visual-studio/

运行带有参数 /exports C:\path\to\AddShow.dll 的 dumpbin 完全没有经过一些研究

http://msdn.microsoft.com/en-us/library/aa446532.aspx 似乎需要从 common/ide 文件夹 dumpbin.exe 中的 mspdb71.dll(现在是 mspdb80.dll)现在运行时出现错误:

致命错误 LNK1106:无效文件或磁盘已满:无法查找 0x6179A 这些线程表明可能是 dumpbin.exe 的版本问题

我有 Microsoft (R) COFF/PE Dumper 版本 9.00.30729.01

所以我尝试了 Microsoft (R) COFF Binary File Dumper Version 5.12.8078,但没有成功。经过大量阅读,我不再靠近

http://support.microsoft.com/kb/815645 http://support.microsoft.com/kb/839286 http://markmail.org/message/p5vwzyfyv3bs6z34 http://fixunix.com/programmer/94825-fatal -error-lnk1106-invalid-file-disk-full.html

当我运行 ProcMon 时,我看到第一次出现 queryopen 和 sqlite3.dll 时 svchost.exe 尝试打开它并失败并出现错误 PATH NOT FOUND。路径是 C:\Program Files\Microsoft Visual Studio 9.0\VC\bin\SQLITE3.DLL 并且是正确的。如果我将它放在 C 驱动器的根目录下,则会出现 NAME NOT FOUND 错误:

C:\Program Files\Microsoft Visual Studio 9.0\VC\bin\link.exe.Local

C:\Program Files\Microsoft Visual Studio 9.0\VC\bin\dumpbin.exe.Local

分别来自link.exe 和dumpbin.exe。我使用的是 XPSP3 而不是 Vista,这是我对 sysinternals 知识的限制。这些 .local 文件是什么?

(csrss.exe 也找不到一些清单文件。)

所以还没有成功,只是更神秘

新增 3:

我尝试从安装位置\Program Files\Microsoft Visual Studio 8\VC\bin 运行dumpbin.exe,但操作系统说找不到mspdb80.dll。我从 \Program Files\Microsoft Visual Studio 8\Common7\IDE 复制了 mspdb80.dll 以尝试让 dumpbin.exe 运行。

现在我收到错误:“c1902 程序数据库管理器不匹配,请检查您的安装”

如果我从 \Program Files\Microsoft Visual Studio 8\VC\bin 中删除 mspdb80.dll,错误就会消失!但我无法运行 dumpbin.exe。

新增4:

我终于能够通过将以下文件复制到文件夹来运行 dumpbin:

dumpbin.exe link.exe lib.exe mspdb80.dll

我确实得到了错误:

致命错误 LNK1248:图像大小 (FFFFFXXX) 超出最大允许大小 (80000000)

一次,但更换 dll 解决了这个问题。估计是坏了?

然后我进入说明中的下一步:http: //www.coderetard.com/2009/01/21/generate-a-lib-from-a-dll-with-visual-studio/ http://support .microsoft.com/kb/131313 并得到错误:警告 lnk4017 statement not supported for the target platform ignored 这原来是因为我指定了 .dll 而不是 .def 文件。

然后将生成的 .Lib 和 .exp 文件添加到 VS2008 项目中并编译和运行。调试器随后报告错误:运行时检查失败 #0 - ESP 的值未在函数调用中正确保存...

如此处所述 “运行时检查失败 #0 - ESP 的值未在函数调用中正确保存”在从 GameSpy 库的 C++ 代码成功回调后, 这是因为我在我的 dll 中使用了 stdcall 并在我的应用程序。

extern "C" { // put Dll C function prototypes here
 int __cdecl AddTwoNum(int n, double f); // __stdcall
}

因此,将其更改为 __stdcall 应该可以解决您认为的问题.. 但可惜没有。

现在我收到一个链接错误:错误 LNK2001:未解析的外部符号 _AddTwoNum@12

出于某种原因,这是一个装饰函数名称。为什么?

添加了 n:

原来这是因为 .lib 文件是使用带有 STDCALL 函数的 dll 制作的。STDCALL 要求调用者清理堆栈,以便将参数的字节数附加到带有 @ 符号的函数名称中。在这种情况下,我有三个 4Byte 整数,总共 12 个字节。

一旦我从使用 CDECL 调用约定创建的 dll 重新制作了 .lib 文件,那么一切都很好。

4

9 回答 9

6

我似乎无法评论他的回答(我需要更多的声誉?),但您可以尝试使用我的.dll 包装器生成器来创建我建议的存根 .dll 。

于 2009-10-08T20:14:17.977 回答
5

我假设您想在 C/C++ 中的 dll 中调用一些函数/方法,而无需访问 lib 文件以与其链接。

如果您知道所需函数的签名,则可以:

  • 创建您自己的 dll 存根版本
  • 创建一个dll项目,与你要使用的dll同名
  • 添加要调用的函数的存根实现
  • 签名非常重要,使用depends.exe 或dumpbin.exe 来检查它们是否匹配。
  • 然后编写/构建您的程序以链接到存根 dll
  • 运行程序用真实的替换存根dll
于 2009-10-08T15:31:43.943 回答
4

您也可以采用动态方式,使用LoadLibrary()GetProcAddress()

(有关示例,请参见第二个链接)。

于 2009-10-08T19:52:03.683 回答
1

我很快就找到了这个例子:http: //www.coderetard.com/2009/01/21/generate-a-lib-from-a-dll-with-visual-studio/

于 2009-10-08T20:47:35.447 回答
1

在 zlib 或 sqlite 等情况下,您可以直接下载源代码并编译您自己的 lib 文件。事实上,前几天我只是为 zlib 做的,我从www.zlib.net下载了源代码(直接下载 zlib 1.2.3)打开提供的 Visual Studio 项目文件并编译了该 lib 的调试和发布版本。我没有尝试过 sqlite,但看到他们有资源,应该不难做到。

如果它是专有 dll,您可以尝试向原始开发人员或公司询问 lib 文件,或者编写您自己的 iain 建议的存根 dll,或者采用 RaphaelSP 的动态路径。

如果它们以 C 语言导出(没有 C++ 名称修改),我会自己走动态路线。

于 2009-10-08T20:08:36.973 回答
0

我已经使用http://wyw.dcweb.cn/dllfaq.htm中的详细信息从 DLL 中获取了一个库。您的里程可能会有所不同。我已经使用它从 python DLL 中获取一个库来构建一些用“C”编写的 python 扩展。

于 2009-10-14T11:22:11.647 回答
0

应该是一个可以进行转换的免费工具。我不确定它是否像“有限试用版”那样“免费”,信息不是很清楚。如果您已经对此进行了测试,请编辑您的问题,我将删除此答案。

于 2009-10-08T09:02:46.223 回答
0

如果您联系 Dll to lib 工具的开发人员,他们可能愿意给您折扣。

我以前遇到过这种情况(我只需要一次昂贵的工具),有时我成功地获得了很大的折扣。

尝试永远不会伤害。

祝你好运。

于 2009-10-08T19:56:34.067 回答
0

开源edll有自己的内部 COFF 加载器。edll 是为完全不同的目的而编写的,但由于它内部有独立的 COFF 加载器,也许可以将您的 .dll 合并到 .exe 内的二进制流或资源中,然后在运行时使用 edll 的 COFF 加载器来加载内置的 dll .

于 2013-01-05T22:49:51.693 回答