是否可以将外部CLI / C ++ DLL作为嵌入式资源或类似内容嵌入到MFC EXE中?我的应用程序目前连接到它旁边的DLL,它具有一些基本功能,如连接数据库,从数据库中提取信息等。
我使用LoadLibrary来使用DLL函数。然后我用selfida保护我的EXE并将EXE和DLL打包在一起。问题是虽然打包DLL和EXE我必须在itida中禁用文件修补,这是一个非常强大的功能。我必须禁用它,因为当我打包我的EXE时,它需要稍微修改一下文件,然后itida认为它已被破解或某些东西,并且不允许应用程序工作。
那么有没有办法将这个DLL嵌入到我的EXE中?该DLL与sadida不兼容,这就是为什么它是一个单独的文件。
答案 0 :(得分:5)
1)在可执行项目中添加资源脚本文件。
IDR_DLL_BIN BINARY MOVEABLE PURE “..\\debug\\myextern.dll”
2)使用资源编译器将RC文件编译为RES文件:
rc.exe /fo ”Release/mydll.res” “.\mydll.rc”
如果您使用的是Visual Studio,它将构建RES文件,并将其与可执行文件绑定。
3)从可执行文件中查找并加载资源:
bool ExtractResource(const HINSTANCE hInstance, WORD resourceID, LPCTSTR szFilename)
{
bool bSuccess = false;
try
{
// Find and load the resource
HRSRC hResource = FindResource(hInstance, MAKEINTRESOURCE(resourceID), _T(“BINARY”));
HGLOBAL hFileResource = LoadResource(hInstance, hResource);
// Open and map this to a disk file
LPVOID lpFile = LockResource(hFileResource);
DWORD dwSize = SizeofResource(hInstance, hResource);
// Open the file and filemap
HANDLE hFile = CreateFile(szFilename, GENERIC_READ | GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
HANDLE hFileMap = CreateFileMapping(hFile, NULL, PAGE_READWRITE, 0, dwSize, NULL);
LPVOID lpAddress = MapViewOfFile(hFileMap, FILE_MAP_WRITE, 0, 0, 0);
// Write the file
CopyMemory(lpAddress, lpFile, dwSize);
// Un-map the file and close the handles
UnmapViewOfFile(lpAddress);
CloseHandle(hFileMap);
CloseHandle(hFile);
}
catch(…)
{
// Whatever
}
return bSuccess;
}
答案 1 :(得分:1)
您可以尝试使用Enigma Virtual Box。这会将DLL打包到EXE中,以便LoadLibrary
“正常工作”。当然,如果它是C ++ / CLI DLL,那么你仍然需要安装.NET框架。