软件分析
软件
软件的下载链接
crackmeesy.zip
分析
点击运行一下,显示的窗口:
输入密码:aaaaaaaaa(随便瞎按的)点击check,如下图所示:
开始破解
1
搜索字符串,发现“10445678951”字样(类似序列,可是不是):
点进去,下断点:
重新加载,并且运行,输入aaaaaaa,点击check,断点处停下来,一步一步F8
基本上就是,输入的字符串第一个字符‘a’的ascii码-0x14,a的十六进制0x61,则做减法以后得到的就是4D,这时候会和10445678951的第一个字符“1”比较。
所以我们可以逆推出序列:
逆推方法
"10445678951"的十进制代码分别是:
49、48、52、52、53、54、55、56、57、53、49
转换为十六进制:
0x31、0x30、0x34、0x34、0x35、0x36、0x37、0x38、0x39、0x35、0x31
集体都加上0x14得到:
0x45、0x44、0x48、0x48、0x49、0x50、0x51、0x52、0x53、0x49、0x45
用字符表示:
E、D、H、H、I、J、K、L、M、I、E
转换过来的序列就是:
EDHHIJKLMIE
C++实现程序:
void getfun(string str){
string mystr="10445678951";
int length=0;
int i=0,j=0;
char s='';
for(i=0;i<str.length();i++){
s=str[i]-0x14;
if(s==mystr[i]){
length++;
}
}
if(length==str.length()){
cout<<"注册成功"<<endl;
}else{
cout<<"注册失败"<<endl;
}
}