DLL内存加载

动态加载dll
功能:
     把一个处于内存里的dll直接加载并且使用。
用途:
     免杀(静态文件查杀),外挂(防止游戏自己hook了loadlibrary等函数),以及其他。
原理: 
    假设目前处于内存里的dll是A,然后开辟一个新的内存空间B,根据A的文件头等相关信息,把B看做是加载内存。
然后把数据拷贝到B里,并且对齐相关节,然后修正iat等相关。然后在手动调用一次dllmain函数,这样dll就被从内存A
加载到内存B里了。之后再调用函数的时候,直接根据函数名,在INT或者其他位置找到函数地址,这个过程就是模拟了
GetProcAddress函数的功能。

整理了一个内存加载dll相关的类以及测试项目代码:(http://download.csdn.net/detail/u013761036/9686863)
下面是相关测试代码:

#include "stdafx.h"
#include <string>
#include <windows.h>
#include <shlwapi.h>
#include "MemLoadDll.h"
#pragma comment(lib, "shlwapi.lib")
using namespace std;
#pragma warning(disable : 4996)


unsigned char bMemory[1024*1024*5] = {0};


DWORD dwLoadDll2Memory(string strDllPath){
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内存加载动态库 MemoryLoadLibrary 有例子。 /* * Memory DLL loading code * Version 0.0.3 * * Copyright (c) 2004-2013 by Joachim Bauch / mail@joachim-bauch.de * http://www.joachim-bauch.de * * The contents of this file are subject to the Mozilla Public License Version * 2.0 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is MemoryModule.h * * The Initial Developer of the Original Code is Joachim Bauch. * * Portions created by Joachim Bauch are Copyright (C) 2004-2013 * Joachim Bauch. All Rights Reserved. * */ #ifndef __MEMORY_MODULE_HEADER #define __MEMORY_MODULE_HEADER #include typedef void *HMEMORYMODULE; typedef void *HMEMORYRSRC; typedef void *HCUSTOMMODULE; #ifdef __cplusplus extern "C" { #endif typedef HCUSTOMMODULE (*CustomLoadLibraryFunc)(LPCSTR, void *); typedef FARPROC (*CustomGetProcAddressFunc)(HCUSTOMMODULE, LPCSTR, void *); typedef void (*CustomFreeLibraryFunc)(HCUSTOMMODULE, void *); /** * Load DLL from memory location. * * All dependencies are resolved using default LoadLibrary/GetProcAddress * calls through the Windows API. */ HMEMORYMODULE MemoryLoadLibrary(const void *); /** * Load DLL from memory location using custom dependency resolvers. * * Dependencies will be resolved using passed callback methods. */ HMEMORYMODULE MemoryLoadLibraryEx(const void *, CustomLoadLibraryFunc, CustomGetProcAddressFunc, CustomFreeLibraryFunc, void *); /** * Get address of exported method. */ FARPROC MemoryGetProcAddress(HMEMORYMODULE, LPCSTR); /** * Free previously loaded DLL. */ void MemoryFreeLibrary(HMEMORYMODULE); /** * Find the location of
### 回答1: 在Delphi中,可以使用`LoadLibrary`函数来加载一个动态链接库(DLL)到内存中。以下是一个简单的示例: ```delphi var hDll: THandle; // 动态链接库句柄 begin // 加载动态链接库 hDll := LoadLibrary('path\to\your\dll.dll'); if hDll = 0 then begin ShowMessage('无法加载动态链接库'); Exit; end; // 使用动态链接库中的函数或过程 // ... // 卸载动态链接库 FreeLibrary(hDll); end; ``` 首先,我们声明了一个变量`hDll`,用于存储动态链接库的句柄。然后,使用`LoadLibrary`函数加载指定路径下的DLL文件。如果加载成功,`LoadLibrary`函数会返回该DLL的句柄;如果加载失败,函数会返回0。 加载成功后,我们可以通过该动态链接库的句柄`hDll`来调用其内部的函数或过程。这些函数或过程的声明通常包含在相应的DLL头文件中。通过调用这些函数或过程,我们可以实现与DLL相关的功能。 最后,在不再需要使用动态链接库时,我们调用`FreeLibrary`函数来卸载该DLL并释放其内存。 需要注意的是,在使用动态链接库时,我们应该遵循相应的DLL文件的使用规则和API文档,确保正确使用并处理异常情况。 ### 回答2: 在Delphi中,我们可以使用LoadLibrary函数来加载DLL文件,并使用GetProcAddress函数来获取DLL中的函数地址。 使用LoadLibrary函数加载DLL文件时,我们需要提供DLL文件的完整路径。可以使用函数的返回值来检查是否成功加载DLL。如果返回值为0,表示加载失败;否则,返回一个非零的句柄,表示成功加载DLL加载成功后,我们可以使用GetProcAddress函数来获取DLL中函数的地址。该函数需要传入DLL的句柄和函数的名称,返回一个指向函数的指针。如果函数不存在,则返回空指针。 完成以上步骤后,我们就可以使用获取到的函数地址来调用DLL中的函数。可以通过指针类型转换来将函数指针赋值给相应的函数变量,然后通过调用该函数变量来调用DLL函数。需要注意的是,调用DLL中的函数需要使用stdcall调用约定,以确保参数传递和堆栈清理的正确性。 在使用完DLL后,我们需要使用FreeLibrary函数来释放DLL所占用的内存。该函数需要传入DLL的句柄,释放成功返回非零值,失败返回0。 通过以上步骤,我们可以在Delphi中成功加载和调用DLL函数,实现内存加载DLL的功能。 ### 回答3: Delphi 是一种流行的编程语言,可以通过内存加载 DLL(Dynamic Link Library)来实现一些功能。内存加载 DLL 意味着将 DLL 文件中的程序代码和数据加载内存中,并通过操作内存中的数据来调用 DLL 中的函数和方法。 在 Delphi 中,可以使用 TMemoryStream 类来实现内存加载 DLL。以下是一个简单的例子: 1. 首先,需要在 Delphi 项目中添加一个引用到 "Classes" 单元。 2. 创建一个 TMemoryStream 对象,并加载 DLL 文件的内容到这个对象中。 ```delphi var MemStream: TMemoryStream; begin MemStream := TMemoryStream.Create; try MemStream.LoadFromFile('path_to_dll.dll'); except // 处理加载 DLL 文件失败的情况 end; // 现在,DLL 文件的内容已经加载内存中 // 可以通过 MemStream 来访问内存中的数据 end; ``` 3. 接下来,可以使用 GetProcAddress 函数来获取内存DLL 文件中指定函数的地址,并将其的地址转换为相应的函数指针。然后,就可以调用该函数了。 ```delphi type TMyFunction = function(params): returnType; var MyFunction: TMyFunction; begin MyFunction := TMyFunction(GetProcAddress(MemStream.Memory, 'function_name')); if Assigned(MyFunction) then begin // 调用函数 MyFunction(params); end; end; ``` 通过以上步骤,我们可以在 Delphi 中实现内存加载 DLL 的功能。这种方法可以用于动态加载 DLL,特别是在某些情况下无法直接从文件系统加载 DLL 文件时。需要注意的是,在使用内存加载 DLL 时要小心内存泄漏和错误处理,以保证程序的稳定性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值