逆向TraceMe.exe
逆向TraceMe.exe
首先我们得找到关键函数,就是关键跳,修改后能够直接破解成功的步骤,我们知道这个程序是有对话框的,所以我们在window的对话框api上下断点
data:image/s3,"s3://crabby-images/6c3d0/6c3d01f58aa0411c5fcfb3a25e73594eb9fe2b3d" alt="img"
首先尝试随便输入用户名和序列号
data:image/s3,"s3://crabby-images/3e6db/3e6db119d632faadd9e9e182e2cb4ca68cd59141" alt="img"
可以看到这个时候触发了断点在0x75D4E290处
data:image/s3,"s3://crabby-images/69427/694275f2f9ef1bf77332faf4d63d29c6ed613165" alt="img"
直接使用f9跳转到返回的地方,跳过一些api函数后,这里这两个我认为应该都是读取对话框的函数。
data:image/s3,"s3://crabby-images/7aa1a/7aa1a032b90ea777e524573be3ff89b35597d130" alt="img"
我们继续单步运行,这里注意到,当运行到图中所示地址时,eax和edx就出现了我们输入的内容
data:image/s3,"s3://crabby-images/6f115/6f1153aa71327ab9a338865197e08b55194a79e1" alt="img"
data:image/s3,"s3://crabby-images/e4d9d/e4d9de9cb53fb2aa722081c5cc44e31a4fe848cd" alt="img"
之后会call 401340这个函数,我认为这个是一个关键函数
data:image/s3,"s3://crabby-images/2eb3b/2eb3ba76246a911d3692bc7eef8e825215b01091" alt="img"
经过调试分析,这个函数的大概逻辑如下
data:image/s3,"s3://crabby-images/8e03b/8e03bbde1a11810dde97fea22386731777f9e057" alt="img"
0x405030的地方存储的数值如下
data:image/s3,"s3://crabby-images/96f2c/96f2c5766e2f5406b284d96f38b7eca98c436773" alt="img"
继续运行,可以看到ecx=7的时候就跳出了这个循环
data:image/s3,"s3://crabby-images/bc020/bc02082e7cad19bcdbcdccd0734c8a96a0c04032" alt="img"
data:image/s3,"s3://crabby-images/de64d/de64df5133d6ad4a41800e57ce6d8110d6d9d4eb" alt="img"
执行完之后,貌似得到2675,可能是密钥值,因为之后的函数把string2“ebp:2675“和string1”abcdefg“进行比较了
data:image/s3,"s3://crabby-images/ba49d/ba49dbfab0a2ccb795a63adc1f4d004f50959fe0" alt="img"
data:image/s3,"s3://crabby-images/aabc2/aabc2966bec6acf3c0b73a1a5c82ba9bd911eba6" alt="img"
data:image/s3,"s3://crabby-images/4f1cf/4f1cf3859e036ec599d6cd82eee661158e3967ae" alt="img"
比较函数过后会来到这个地方,test eax,eax,表示eax为1时跳转,这里我们的eax是0,尝试修改为jne
data:image/s3,"s3://crabby-images/5f5c8/5f5c8668eb748cf816e1fddc0b2745268fae1c0d" alt="img"
之后可以看到是成功的,说明这个就是关键跳
data:image/s3,"s3://crabby-images/8d19e/8d19edb2e16ac1046aadde8508cf4e736cc2a321" alt="img"
我们要写一个注册机程序那就得先逆向他的加密代码,根据我们判断以下的逻辑
data:image/s3,"s3://crabby-images/79a4e/79a4ee027f36058b334e8d8c5b3e6db04426beff" alt="img"
写出python脚本代码如下
1 |
|
data:image/s3,"s3://crabby-images/d3b2a/d3b2afa5b57c3f7475807e9393ae52a4686e8378" alt="img"
验证
本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!,本博客仅用于交流学习,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,文章作者不为此承担任何责任。 文章作者拥有对此站文章的修改和解释权。如欲转载此站文章,需取得作者同意,且必须保证此文章的完整性,包括版权声明等全部内容。未经文章作者允许,不得任意修改或者增减此文章内容,不得以任何方式将其用于商业目的。若造成严重后果,本人将依法追究法律责任。 阅读本站文章则默认遵守此规则。