{高三党分享}VB使用函数指针动态调用DLL

myjisgreat 2011-10-07 06:07:42
下载 http://download.csdn.net/download/myjisgreat/3662575


前些日子突发奇想。长假碰电脑的时间基本都耗在这个东西上了,最窘的是写好后才发现网上竟然有类似代码。。。。。不过我的代码比他短小,姑且发上来献献丑吧

动态调用DLL的前两步VB都可以做到,LoadLibrary & GetProcAddress得到函数指针。可是由于VB不支持函数指针的调用,貌似到这一步就走不下去了。
不过因为VB内部函数、DLL函数(包括API函数)都使用STDCALL调用方式,我们可以手动把参数送入堆栈,然后CALL这个函数,也就达到了效果(不过要用汇编完成)
这就直接交给VC的dll完成吧

long WINAPI __stdcall CallProc(long addr,long *Param,long Count)
{

long i;long par;

for (i=Count;i>=1;i--)
{ par=*Param;
__asm{
push par
}
Param--;

}

__asm{
call addr
mov i,eax
}

return i;

}

这个函数将参数一一PUSH进堆栈,然后CALL(网上代码用VB+汇编完成,代码量巨大,个人觉得不值)


于是VB调用就很简单了,VB中把参数填入Long类型的数组中,调用CallProc,addr代表函数指针, pPrarm代表刚刚填好的参数数组的最后一个参数的地址(用VarPtr取得),conut代表参数数量,比如
Dim hModule As Long, pProc As Long,p(1) as Long
hModule = LoadLibrary("user32")
pProc = GetProcAddress(hModule, "FlashWindow")
If pProc <> 0 Then
p(0)=Me.Hwnd 'FlashWindow第一个参数
p(1)=1000 'FlashWindow第2个参数
Form1.Print CallProc(pProc, VarPtr(p(1)),2)
Else
MsgBox "err"
End If
FreeLibrary hModule



为方便调用,我简单封装了一个VB函数
Public Function StdCall(lpAddr As Long, ParamArray Param()) As Long
Dim p() As Long
If UBound(Param) <> -1 Then
ReDim p(0 To UBound(Param))
Dim i As Integer
For i = 0 To UBound(Param)
p(i) = Param(i)
Next i
StdCall = CallProc(lpAddr, VarPtr(p(UBound(Param))), UBound(Param) + 1)
Else
StdCall = CallProc(lpAddr, 0, 0)
End If
End Function

比如上面的FlashWindow就可以StdCall pProc,Me.Hwnd,1000来用了
...全文
326 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
贝隆 2011-10-17
  • 打赏
  • 举报
回复
看看,学习
王二.麻子 2011-10-17
  • 打赏
  • 举报
回复
一定要嵌汇编进去嘛..
可以自己写个函数..函数里面随便写点垃圾代码
然后自己用操作PE文件的方式,在内存中找到这个自己编写的函数的跳转地址..把你找到的dll的入口地址填进去,按照调用自己函数的方式直接调用..

在调试器里么弄过成功了,实际还没操作过
myjisgreat 2011-10-15
  • 打赏
  • 举报
回复
我觉得还行啊
嗷嗷叫的老马 2011-10-07
  • 打赏
  • 举报
回复
拖上一个DLL的话,这是很多人所不愿意的
myjisgreat 2011-10-07
  • 打赏
  • 举报
回复
长假结束了,受不鸟啊,明天就考试
内容概要:本文详细记录了对一个Android ARM64静态ELF文件中字符串加密机制的逆向分析过程。该ELF文件的所有字符串均被加密,无法通过常规strings命令或IDA直接识别。作者通过分析发现,加密字符串存储在.rodata段,其解密所需信息(包括密文地址、长度和16位密钥)保存在.data.rel.ro段的40字节描述符中。核心解密函数sub_10F408采用自反的双pass流密码算法,结合固定密钥KEY_TERM(由.data段24字节数据计算得出),实现字节级非线性、位置与长度相关的加密。文章还复现了完整的Python解密脚本,并揭示了该保护机制的本质为代码混淆而非强加密,最终成功批量解密全部956条字符串,暴露程序真实行为,如shell命令模板、设备标识篡改、网络重置等操作。此外,文中还提及未启用的自定义壳框架及其反dump设计。; 适合人群:具备逆向工程基础的安全研究人员、二进制分析人员及对ELF保护技术感兴趣的开发者。; 使用场景及目标:①学习ELF二进制中字符串加密的典型实现方式与逆向突破口;②掌握从结构识别、函数追踪到算法还原的完整逆向流程;③理解“绑定二进制”的完整性校验设计及其局限性;④实践编写IDAPython脚本自动化提取与解密敏感数据。; 阅读建议:此资源以实战案例驱动,不仅展示技术细节,更强调逆向思维与验证方法,建议读者结合IDA调试环境,逐步跟随文中步骤进行动态分析与算法验证,深入理解每一步的推理依据。

7,788

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧