反沙箱初探-函数实现6

沙箱在模拟有些函数的时候,虽然功能已经模拟了,但是将其模拟的功能和原生api进行比较,发现有些执行的分支并没有模拟到。

在kernel32.dll中,如果lstrcpynA的第三个参数iMaxLength为0,则返回值为第一个参数lpString1。但是沙箱模拟时却直接返回零。导致发生了异常。不同的沙箱模拟的好坏不一样,有些沙箱模拟的比较好,执行不会产生异常。

图1 执行lstrcpynA

图2 kernerl32.dll的lstrcpynA实现

解决方案:模拟lstrcpynA实现,覆盖分支路径。如果lstrcpynA的第三个参数iMaxLength为0,则返回值为第一个参数lpString1。

hash:e0cd322ab4cea356eb8092887c7bc025ff672e6c

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值