使用Resource Hacker+IDA定位程序验证逻辑,不熟悉可以参考我的逆向技术栏目相关文章,可以得出等价伪代码以及对应注册算法如下
#include<iostream>
using namespace std;
/*void main(HWND hWnd)
{
UINT iSLen; // ebx@1
int result; // eax@2
UINT iNLen; // esi@3
int i; // edi@5
char szSerial[42]; // [sp+Dh] [bp-7Bh]@1
char szName[40]; // [sp+36h] [bp-52h]@3
char szMix[42]; // [sp+5Eh] [bp-2Ah]@6
char szSerial[42];
int iSLen = GetDlgItemTextA(hWnd, 102, &szSerial, 40);
if ( iSLen )
{
int iNLen = GetDlgItemTextA(hWnd, 101, szName, 40);
if (iNLen >= 8)
{
for (i=0; i<iNLen; ++i)
{
szMix[iNLen-i] = (i^iSLen) + (i^szName[i]);
if (szMix[iNLen - i]<32 )
szMix[iNLen-i] += 32;
if (szMix[iNLen - i] >= 128)
szMix[iNLen - i] = 32;
if ( szSerial[iNLen-i] != szMix[iNLen-i] )
{
MessageBoxA(hWnd, off_402044, off_402040, 0);
return 0;
}
}
MessageBoxA(hWnd, off_40203C, off_402038, 0);
result = 1;
}
else
{
MessageBoxA(hWnd, lpText, lpCaption, 0);
result = 0;
}
}
else
{
result = 0;
}
return result;
}*/
void main()
{
int iNLen = 8;
int iSLen = 8;
char szMix[40];
char szName[]="@@@@@@@@";
for (int i = 0; i < iNLen; ++i )
{
szMix[iNLen - i] = (i ^ iSLen) + (i ^ szName[i]);
if ( szMix[iNLen - i] < 32 )
szMix[iNLen - i] += 32;
if ( szMix[iNLen - i] >= 128 )
szMix[iNLen - i] = 32;
}
szMix[0]='0';
szMix[9]='\0';
cout<<szMix<<endl;
}