程序使用Virtual Basic写的 无壳
分析程序
data:image/s3,"s3://crabby-images/28215/28215bec7fec32600f55c537b53cd19bfcefe889" alt="21"
you get wrong try again
程序是使用用户名和序列号的方式加密 载入OD 随便输入一个 用户名和密码 来到第一处关键校验处
data:image/s3,"s3://crabby-images/51361/513612cb2fcb584840c23562ee4c4cd70ac1458a" alt="22"
往上找看看函数的主要算法在哪里
data:image/s3,"s3://crabby-images/0427b/0427be8f2ef3a8126acccb0e5227e74bb42b904a" alt="23"
data:image/s3,"s3://crabby-images/13dd6/13dd6f9e1101b418578b12d29bf70b77f54dcb19" alt="24"
求出了用户名的长度
将用户名长度乘以0x17CFB 得到结果 如果溢出则跳转
将结果再加上用户名的第一个字 符的ASCII
将结果转为十进制
将结果和AKA进行拼接 得到最后的序列号
注册机
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
| #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include <stdlib.h> #include <windows.h> int main() {
char key1[4] = "AKA";
char username[10] = { 0 }; printf("请输入用户名:"); scanf_s("%s", username, 10);
int iUsernameLen = strlen(username);
int result = iUsernameLen * 0x17CFB;
result = result + username[0];
char key[MAX_PATH] = { 0 }; sprintf(key, "%s-%d", key1, result);
printf("生成的序列号为:%s\n", key); system("pause"); return 0; }
|
data:image/s3,"s3://crabby-images/15c77/15c77f74757daa0279ea9ab43c64047d585c43f2" alt="25"