软件介绍:
ColorSchemer Studio 2 is a professional color matching application for anyone from hobbyists to advanced professionals.
Work with a dynamic visual color wheel, instantly explore harmony relationships and even let ColorSchemer Studio intelligently suggest color schemes for you!
官网:http://www.colorschemer.com/
从一个论坛上看到的一篇文章,尝试了下。发现这个版本号和他的那个版本号不同,算法也有些不同。
所以就自己尝试破解了下。
软件注冊时明文比較。载入起来后直接读取内存就能读到真正的注冊码,我们跟踪一下算法。。
。。
1. 载入后,使用字符串找注冊的keyword,就能够找到这个地方
能够看出注冊过程是,先算出一大坨数据。然后取注冊时输入的code1和code2,连接code1和code2记为CODE,然后比較算出的这一大坨数据是不是和CODE相等,相等则注冊成功,不相等就注冊失败。。
2. 来到算出一大坨数据的地方
来到算法的第一部分。计算出一个key1(中间值),它是怎么计算的呢?事情的经过是这个的:取出输入的username的每一位,乘以1024后。求和。
然后表示成十进制。结果记为KEY1。
3. 接着向后走,来到
上面的计算过程是这种:每次计算一个数,(name[i] % 10 + key1[i]) % 10,然后这个数通过以下的CALL 00404DCC进行赋值。
4. 赋值的过程
进入00405150后
5.依据username的长度为8,生成的这八位数字所有赋完值后。就生成了注冊码的后八位。
而注冊码的前面的八位又是两部分来的:第一部分是固定的“CSS”,第二部分是key1的前五位。
看上图,堆栈中三个串凑齐了,连接起来就是注冊码。。。。
自己逆向出来的算法:
TCHAR szUserName[256] = {0};
::GetDlgItemText(this->m_hWnd, IDC_EDT_UserName, szUserName, 256);
if (strlen(szUserName) != 8)
{
AfxMessageBox("username必须为八位的字母或数字...:)");
return ;
}
DWORD key1 = 0;
for (int i = 0; i < strlen(szUserName) ; i++)
{
DWORD dwTemp = (TCHAR)szUserName[i] * pow(2, 16);
key1 += dwTemp;
}
TCHAR szTempResult[10] = {0};
itoa(key1, (TCHAR*)szTempResult, 10);
TCHAR strResult[17] = {0};
for (i = 0; i < strlen(szUserName); i++)
{
DWORD dwTemp1 = szUserName[i] % 10;
DWORD dwTemp2 = szTempResult[i] - 0x30;
DWORD dwTemp3 = dwTemp1 + dwTemp2;
DWORD dwTemp4 = dwTemp3 % 10;
strResult[i+8] = dwTemp4 + 0x30;
}
for (i = 0; i < 5; i++)
{
strResult[i+3] = szTempResult[i];
}
strResult[0] = ‘C‘;
strResult[1] = ‘S‘;
strResult[2] = ‘S‘;
::SetDlgItemText(this->m_hWnd, IDC_EDT_Code, strResult);下载地址:http://download.csdn.net/detail/xiaocaiju/7493841 压缩password:xiaoju
原文:http://www.cnblogs.com/brucemengbm/p/6752875.html