序列号解决过程分析

软件分析

软件

软件的下载链接
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;
	}

}

猜你喜欢

转载自blog.csdn.net/wangzhiyu12/article/details/109544707
今日推荐