逆向学习——注册机

1.在输入一个错误的注册码时,软件在比较的时候,正确的注册码可能会出现在附近,这个时候可以用内存编辑软件winhex等或者OD去查找内存,查找内容就是你输入的错误的注册码,如果软件作者不注意这点,采用了明码比较,那么就很容易找出真正的注册码
2.使用注册机软件keymake制作注册机,也是需要自己手动分析出正确密码出现的断点(这个适合于明码比较)
3.非明码比较的例子
随便输入:
在这里插入图片描述
得到:
在这里插入图片描述
这个时候根据信息,可以采用搜索字符串,或者根据调用的GetDlgItemTextA函数来下断点,我采用的是字符串搜索:
在这里插入图片描述
可以看到这段函数开始的地址是401362,用IDA打开程序,寻找调用此处的地址:
在这里插入图片描述
在这里插入图片描述

发现是401245,然后回到OD
在这里插入图片描述
里面40137E和4013D8分别是处理用户名和密码的,K1=F1(用户名),K2=F2(密码),如果K1=K2,则验证通过,分别进入两个函数分析,可以手动分析,也可以借用IDA的F5功能
先将输入的用户名转换成大写字母:
在这里插入图片描述
再把每个字节对应的16进制数加起来
在这里插入图片描述
然后将得到的数与0x5678异或,结果就是K1
在这里插入图片描述
对密码的分析
在这里插入图片描述
很简单的算法,将每个字节的ebx=ASCII值-48,edi与10相乘加上ebx的结果赋给edi,直到每个字节结束。表达式就是edi=edi*10+(ebx-48),然后最终的EDI在与0x1234异或得到K2
这个时候我们直到K1=a0x5678,K2=b0x1234 K1和K2同时异或0x1234依然相等,所以a0x56780x1234=b,所以我们只需写出计算这个步骤的值就能破解,注册机的软件书写要用到VC知识,暂时不会,我就用c语言写的
在这里插入图片描述
用户名输入长度为10,cchMax值为0bh,长度为0b-1=10
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这种办法是要完全弄清楚算法,还可以不用理解算法,直接内嵌汇编代码,我慢慢学,慢慢写

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值