破解入门学习笔记题三十八

用VB反汇编查看

global_76

  1. 初始赋值 ​:在 Form_Initialize事件中,global_76 = &H45A0(十六进制),转换为十进制是 ​17824

  2. 计算结果 ​:在 Form_Load事件中,执行 global_76 = CLng(Fix((CDbl(global_76) * 3.1124)))。即 17824 * 3.1124 = 55475.4176,再经 Fix函数截断小数部分 取整,得到 ​55475

var_94

  1. ASCII拼接​:将用户名每个字符的ASCII码拼接成数字字符串。

  2. 除以π简化 ​:循环执行 var_94 = Fix(var_94 / 3.141592654),直到其长度≤9位。

  3. 异或运算 ​:var_94 = var_94 Xor &H30F85678(&H30F85678的十进制是821580432)。

  4. 减去global_76 ​:var_94 = var_94 - 55475

(用户注册码 - var_94) = 用户名长度是否成立。

复制代码
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h> 
​
// 模拟VB6的Fix函数(向零取整)
__int64 vb6_fix(double number) {
    if (number >= 0) {
        return (__int64)floor(number);
    } else {
        return (__int64)ceil(number);
    }
}
​
__int64 calculate_registration_code(const char* username) {
    char ascii_str[256] = "";
    int len = strlen(username);
​
    // 1. ASCII拼接
    for (int i = 0; i < len; i++) {
        char temp[10];
        sprintf(temp, "%d", (int)username[i]);
        strcat(ascii_str, temp);
    }
    
    // 将字符串转换为__int64
    __int64 s = _atoi64(ascii_str);
    
    // 2. 循环除以π简化
    char temp_buf[50];
    while (strlen(ascii_str) > 9) {
        s = vb6_fix((double)s / 3.141592654);
        sprintf(ascii_str, "%I64d", s);
    }
    
    // 3. 后续运算
    s = s ^ 0x30F85678;
    s = s - 55475;
    s = s + len;
    
    return s;
​
}
​
​
int main() {
    char username[100];
    
​
    printf("请输入用户名: ");
    scanf("%s", username);
    
    // 计算注册码
    __int64 registration_code = calculate_registration_code(username);
    
    printf("用户名: %s\n", username);
    printf("注册码: %I64d\n", registration_code);
    
    // 验证计算公式
    int name_len = strlen(username);
    __int64 intermediate_value = registration_code - name_len;
    printf("验证: (%I64d - %I64d) = %d\n", registration_code, intermediate_value, name_len);
    
    return 0;
​
}
相关推荐
L.fountain17 小时前
图像自回归生成(Auto-regressive image generation)实战学习(一)
人工智能·深度学习·学习·计算机视觉·图像自回归
WizLC18 小时前
【JAVA】JVM类加载器知识笔记
java·jvm·笔记
TL滕18 小时前
从0开始学算法——第十八天(分治算法练习)
笔记·学习·算法
蓝桉~MLGT18 小时前
Ai-Agent学习历程—— Agent认知框架
人工智能·学习
لا معنى له19 小时前
学习笔记:卷积神经网络(CNN)
人工智能·笔记·深度学习·神经网络·学习·cnn
蒙奇D索大19 小时前
【数据结构】考研408 | 冲突解决精讲: 拉链法——链式存储的艺术与优化
数据结构·笔记·考研·改行学it
_Minato_19 小时前
数据结构知识整理——复杂度的计算
数据结构·经验分享·笔记·算法·软考
x_lrong19 小时前
交叉验证笔记
笔记
لا معنى له19 小时前
学习笔记:注意力机制(Attention)、自注意力(Self-Attention)和多头注意力(Multi-Head Attention)
笔记·学习
走在路上的菜鸟19 小时前
Android学Dart学习笔记第十六节 类-构造方法
android·笔记·学习·flutter