于是从exe上的createprocess入手
data:image/s3,"s3://crabby-images/8fecd/8fecdd3212192336a456863d0a094cdad4648358" alt=""
CreateProcessA,od调试给断点
data:image/s3,"s3://crabby-images/1af1d/1af1da0426a9aa10e19504f6dd8becbea04e6669" alt=""
createprocess创建进程,createflag使用创建即挂起主线程,writeprocessmemory写进程内存,修改entrypoint
然后suspendthread唤醒主线程
在writeprocessmemory后dump SnailMail.RWG的内存下来
data:image/s3,"s3://crabby-images/ae35c/ae35cfa0f46961c15375f8d8c5add4290f3a813e" alt=""
运行发现依然Error,这次可以给messagebox下断了
data:image/s3,"s3://crabby-images/1ed08/1ed08f71c870a1b9a234dd9fdb5f54c1cbed388e" alt=""
来到这里,再看看堆栈,找到返回函数
data:image/s3,"s3://crabby-images/951f8/951f808daf7a92204f158e004c8100a8bd05e0f0" alt=""
cmp eax,801
jge 大于等于跳转
断点发现运行messagebox的call前eax=800
跟入前面的call看看