逆向——VB调试

这篇博客主要介绍了VB的调试技巧和常用函数,包括N-code和P-code两种编译方式,以及在逆向工程中常见的数据类型转换、数据移动、数学运算等功能函数。在调试过程中,提到了如何拦截警告声、进行数据类型转换和数值运算。此外,还讨论了VB中的循环结构、字符串操作和比较函数,对于动态跟踪和分析算法具有指导意义。
摘要由CSDN通过智能技术生成

VB调试

因为VB的程序有单独的一个库,所以专门说明。

认识VB

两种编方式
  • N-code:VB 5.0以后,为了改善VB的运行速度
  • P-code:VB 4.0以前,此代码CPU不能直接运行,需要通过特殊的解释器翻译
VB逆向中常用的函数:
数据类型转换
  • __vbaI2Str:将一个字符串转为8 位(1个字节)的数值形式(范围在 0 至 255 之间) 或2 个字节的数值形式(范围在 -32,768 到 32,767 之间)。
  • __vbaI4Str:将一个字符串转为长整型(4个字节)的数值形式
  • __vbar4Str:将一个字符串转为单精度单精度浮点型(4个字节)的数值形式
  • __vbar8Str:将一个字符串转为双精度单精度浮点型(8个字节)的数值形式
  • VarCyFromStr:(仅VB6库. 要调试,则在WINICE.DAT里必须有 OLEAUT32.DLL)字符串到变比型数据类型
  • VarBstrFromI2:(仅VB6库. 要调试,则在WINICE.DAT里必须有 OLEAUT32.DLL)整型数据到字符串
数据移动
  • __vbaStrCopy:将一个字符串拷贝到内存,类似于 Windows API HMEMCPY
  • __vbaVarCopy:将一个变量值串拷贝到内存
  • __vbaVarMove:变量在内存中移动,或将一个变量值串拷贝到内存
数学运算
  • __vbavaradd:两个变量值相加
  • __vbavarsub:第一个变量减去第二个变量
  • __vbavarmul:两个变量值相乘
  • __vbavaridiv:第一个变量除以第二个变量,得到一个整数商
  • __vbavarxor:两个变量值做异或运算
程序设计杂项
  • __vbavarfornext:这是VB程序里的循环结构, For… Next… (Loop)
  • __vbafreestr:释放出字符串所占的内存,也就是把内存某个位置的字符串给抹掉
  • __vbafreeobj:释放出VB一个对象(一个窗口,一个对话框)所占的内存,也就是把内存某个位置的一个窗口,一个对话框抹掉
  • __vbastrvarval:从字符串特点位置上获取其值
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值