逆向学习-简单逆向分析1

举报
亿人安全 发表于 2023/05/31 23:50:32 2023/05/31
【摘要】 程序效果输入一串字符串 然后输出key right或者error内部肯定是进行了判断 因为这里打印了 字符 我们可以直接通过这些关键词 来搜寻到 函数的入口在od里面然后回车进去看到error了 也看到right了 那应该是找对了 然后往上翻 找到函数的入口 F2打上断点 执行到这初步分析 这里定义了5个局部变量然后add esp在call后面 这应该就是外平栈 cdecl push传参然后...

程序效果

输入一串字符串 然后输出key right或者error

内部肯定是进行了判断 因为这里打印了 字符 我们可以直接通过这些关键词 来搜寻到 函数的入口

在od里面

然后回车进去

看到error了 也看到right了 那应该是找对了 然后往上翻 找到函数的入口 F2打上断点 执行到这

初步分析 这里定义了5个局部变量

然后add esp在call后面 这应该就是外平栈 cdecl push传参

然后看下面这个call push了2次 然后在call的后面 外平栈 0x8 那应该是 只传了这两个参数

然后继续F8运行 但运行到call 走不动了 然后程序提示输入 那这个函数应该就是获取输入的值

但是通过这里可以发现 是将第一个局部变量的地址传了进去 但前面又是赋值的0 是int型 输入的又是字符串型 对不上啊 前面的5个局部变量又是地址挨着的 那可以猜测 不是5个局部int变量 而是一个char类型的数组 然后将首地址传了进去 这样就对得上了

然后在程序框输入123456 然后执行

可以发现 函数执行后 又将数组的第一个地址给了edx 然后push到了 下一个call 因为在call后面是add esp,0x4 那应该就只传了一个参数 就是push的edx

后面的这一个函数我们先不跟进 就先直接执行 然后看看寄存器值的变化

发现eax变成了0 因为一般eax是函数的返回值 但也不一定 然后看后面 又用到了eax 那大概率就是返回值了

然后看后面cmp 又和0比较 然后je跳转 直接跳到了error 那如果要返回正确 就要eax返回的值不是0 是其他的或者1

je 主要是根据ZF标志寄存器来判断的只要ZF不为1就行 或者直接将je 用 nop填充 也直接执行right


但是这样没有拿到 正确的key 为了拿到正确的key 我们跟进那个判断的函数

发现这个函数push了两个值 一个hello51hook 还有一个从地址取出存到eax里面

ebp+8 就是我们输入的值 也就是函数传参的第一个参数

通过add esp 0x8 也可以判断出 这个call 接收了2个参数

然后执行完call 发现eax变成的FFFFFFFF 也就是-1

然后看后边 test eax eax 与运算 除了0与0 为0 其他的与本身肯定是不为0的 然后jnz跳转 FFFFFF 肯定运算出来不为0 所以是要跳转的

看下面 直接跳转到xor 清空eax 然后就返回0出去了

所以这个函数就相当于判断传入的字符串与hello51hook是否相等 相等肯定返回出去的就是1了

如果相等的话 ZF就会是1 会给eax 1 然后直接执行jmp跳转到下面就返回出去了

然后现在正确的key也拿到了 就不用分析了后面

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。