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

用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;
​
}
相关推荐
r i c k4 小时前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦4 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
shandianchengzi5 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
浅念-5 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
ZH15455891315 小时前
Flutter for OpenHarmony Python学习助手实战:API接口开发的实现
python·学习·flutter
爱吃生蚝的于勒5 小时前
【Linux】进程信号之捕捉(三)
linux·运维·服务器·c语言·数据结构·c++·学习
奶茶精Gaaa5 小时前
工具分享--F12使用技巧
学习
The森6 小时前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix
tq10866 小时前
Skills 的问题与解决方案
笔记
三水不滴6 小时前
有 HTTP 了为什么还要有 RPC?
经验分享·笔记·网络协议·计算机网络·http·rpc