file-type

MC_Crypt加密库:支持多平台的多种加密解决方案

RAR文件

3星 · 超过75%的资源 | 下载需积分: 7 | 678KB | 更新于2025-09-10 | 192 浏览量 | 10 下载量 举报 收藏
download 立即下载
MC_Crypt 加密库是一套功能强大且易于使用的软件加密库,专为多种开发平台设计,旨在为开发者提供全面的加密解决方案。该加密库集成了多种主流的加密算法,包括但不限于 AES(高级加密标准)、DES(数据加密标准)、MD5(消息摘要算法第五版)、SHA(安全哈希算法)以及 RSA(非对称加密算法)等,能够满足不同场景下的数据加密、解密、签名与验证等需求。 首先,从标题“MC_Crypt 加密库”来看,“MC_Crypt”应为该加密库的名称,其命名可能体现了“Multi Cipher”或“Multiple Cryptographic”之意,暗示其支持多种加密算法。而“加密库”则说明它是一个软件开发库,供开发者在编写应用程序时调用其接口实现加密功能。这类库通常以动态链接库(DLL)或静态库的形式提供,支持多种开发语言和开发环境。 从描述来看,MC_Crypt 加密库的显著特点是其广泛的兼容性和易用性。它可以在多种开发平台下使用,包括 VC(Visual C++)、VB(Visual Basic)、Delphi 等流行的开发工具。这意味着无论是使用 C/C++ 进行系统级开发,还是使用 VB 进行桌面应用开发,抑或是使用 Delphi 编写 Windows 应用程序,开发者都可以轻松地集成该加密库,并调用其提供的加密函数。此外,描述中还提到“附有各开发工具下的样例程序”,这表明该库的发布者提供了丰富的示例代码,帮助开发者快速上手,理解如何在不同的开发环境中使用该加密库,从而提高开发效率。 接下来,我们详细分析该加密库所支持的各类加密算法: 1. **AES(Advanced Encryption Standard,高级加密标准)** AES 是一种对称加密算法,被广泛用于保护敏感数据。它支持 128、192 和 256 位密钥长度,具有较高的安全性和加密效率。AES 通常用于数据加密,如文件加密、数据库加密、网络通信加密等场景。MC_Crypt 加密库提供 AES 算法的实现,意味着开发者可以使用该库对数据进行高强度加密,确保数据在传输和存储过程中的安全性。 2. **DES(Data Encryption Standard,数据加密标准)** DES 是早期广泛使用的对称加密算法,采用 56 位密钥。尽管 DES 因其密钥长度较短而逐渐被更安全的算法取代,但其变体 3DES(三重 DES)仍被一些旧系统使用。MC_Crypt 提供 DES 支持,可能包括 DES 和 3DES 两种模式,适用于需要与旧系统兼容的场景。 3. **MD5(Message-Digest Algorithm 5,消息摘要算法第五版)** MD5 是一种广泛使用的哈希算法,用于生成数据的唯一指纹。尽管 MD5 因其存在碰撞漏洞而不推荐用于安全敏感场景(如密码存储、数字签名等),但它仍常用于校验文件完整性、快速生成数据摘要等用途。MC_Crypt 提供 MD5 算法,说明其支持数据摘要生成,可用于验证数据是否被篡改。 4. **SHA(Secure Hash Algorithm,安全哈希算法)** SHA 是一组更安全的哈希算法,包括 SHA-1、SHA-2(如 SHA-256、SHA-512)以及最新的 SHA-3。SHA-1 虽然仍被部分系统使用,但由于其安全性问题,已被逐步淘汰。SHA-2 系列是目前主流的哈希算法,广泛用于数字证书、SSL/TLS 协议、区块链等领域。MC_Crypt 加密库支持 SHA 算法,意味着它可以生成高强度的数据摘要,适用于需要高安全性的应用场景。 5. **RSA(Rivest–Shamir–Adleman,非对称加密算法)** RSA 是最常用的非对称加密算法之一,广泛用于数字签名、身份验证、密钥交换等场景。与对称加密不同,RSA 使用公钥和私钥进行加密和解密,具有更高的安全性。例如,开发者可以使用 RSA 算法对数据进行签名,并通过公钥验证签名的合法性,确保数据来源的可信性。MC_Crypt 提供 RSA 实现,意味着该加密库不仅支持数据加密,还支持数字签名和验证,增强了其在安全通信、身份认证等方面的应用能力。 此外,从标签“AES DES MD5 SHA RSA”来看,MC_Crypt 加密库涵盖了现代加密技术中最常用的核心算法。这些算法分别属于对称加密、哈希摘要和非对称加密三大类,几乎涵盖了数据安全处理的全部基础需求。因此,MC_Crypt 可以作为开发者在构建安全系统时的重要工具库。 压缩包文件名称列表中仅有一个文件:“MC_Crypt加密库”,这表明压缩包中可能包含了该加密库的完整内容,包括但不限于: - 加密库的核心 DLL 或静态库文件; - 各种开发工具(VC、VB、Delphi)下的调用示例; - API 接口文档和使用说明; - 测试工具或演示程序; - 安装脚本或部署指南。 总结来看,MC_Crypt 加密库是一个面向多种开发平台的综合性加密解决方案,其提供的 AES、DES、MD5、SHA、RSA 等算法覆盖了现代加密技术的核心功能。无论是进行数据加密、完整性校验还是身份验证,开发者都可以借助该库快速实现安全功能,并通过附带的示例程序迅速掌握其使用方法。对于需要在 VC、VB、Delphi 等环境中集成加密功能的开发者而言,MC_Crypt 是一个非常实用的工具。

相关推荐

filetype

通过以下代码爬取到的视频只有声音怎么解决import requests headers = { 'Cookie': 'ttwid=1%7CPxueRcOuZUm5vJchkcnC-Zx-Z9RBSmcSdCGgW7npV1Y%7C1735724604%7C1b6714b66c5a4771487f1f947ea1e6b107ab66ae56f56569f7bb870cb61286c2; UIFID_TEMP=26198ff38959f773c63a6fc9b3542e2fdcfd2f10d2782124ed1adc24709862dfaede920a87e78efdbd8899bbfcda446e57b9aab934bc52693d617ac8261fda8d61f9abfa4cb1c744813c2e7b883d16e2; WebUgChannelId=%2230001%22; xgplayer_user_id=864065415642; fpk1=U2FsdGVkX1+oxoVTP+ebCh47ZhX6ctV7N/9VW3G7H3ekvpe8pwVVEWS4VYSyPjFkOknVLECX2HGBQHTA7UJOGQ==; fpk2=ffc3218438300d069a0fd5dfa5c6e851; bd_ticket_guard_client_web_domain=2; UIFID=26198ff38959f773c63a6fc9b3542e2fdcfd2f10d2782124ed1adc24709862dfaede920a87e78efdbd8899bbfcda446e48d07ce299733b445ce01a4d9c18d15cc0582af897fb77e1a824d51419337bca0283ee590a37ffbadf984d51c485a4a347e8dce606f053aa2aa283a249bfe8200b0a738144132975d25dd7cdad6e7723c146ea1f30456b28c271ae2771033784f5d498a62d94691ed4e04a1b08183445; live_use_vvc=%22false%22; __security_mc_1_s_sdk_crypt_sdk=f66ad3d8-40eb-b735; __security_mc_1_s_sdk_sign_data_key_sso=1ecb63f3-4fed-ad4d; xgplayer_device_id=82329168259; FORCE_LOGIN=%7B%22videoConsumedRemainSeconds%22%3A180%2C%22isForcePopClose%22%3A1%7D; passport_csrf_token=7b1865ec434a4962c895c2b75be050ff; passport_csrf_token_default=7b1865ec434a4962c895c2b75be050ff; s_v_web_id=verify_m7smnn6b_amP2N6OV_cKVA_4K0T_8tXd_ynkb0RuSYzip; n_mh=YblwJCY6Bf83Xv3orTKcvfYuIINr6dx0K4mRG1rr80M; is_staff_user=false; store-region=cn-hl; store-region-src=uid; publish_badge_show_info=%220%2C0%2C0%2C1741486253192%22; SelfTabRedDotControl=%5B%5D; __security_mc_1_s_sdk_cert_key=b5aea1d0-4bae-83d0; __security_server_data_status=1; my_rd=2; WallpaperGuide=%7B%22showTime%22%3A1741342652117%2C%22closeTime%22%3A0%2C%22showCount%22%3A3%2C%22cursor1%22%3A47%2C%22cursor2%22%3A14%2C%22hoverTime%22%3A1740926977925%7D; passport_mfa_token=CjcHndR66ol8aFbi7r0ba%2Fmm9PVKQwieyzqsuGJF%2F7CrUnbpmSflYlFRvSiRC%2FajXn1bKYnY6Q1nGkoKPAf0D5NjK3GW83YPL6U9VbPDb4jplUPh7OHA6GyYGI1nGwm%2BkCUXKUoawAuKj

filetype

#include <Windows.h> #include <Wbemidl.h> #include <comdef.h> #include <WinCrypt.h> #include <string> #include <algorithm> #include <sstream> #include <vector> #include <commctrl.h> #include <iomanip> // 添加缺失的头文件 #pragma comment(lib, "wbemuuid.lib") #pragma comment(lib, "Advapi32.lib") #pragma comment(lib, "Crypt32.lib") #pragma comment(lib, "comctl32.lib") // 资源ID定义 #define IDD_MAIN_DIALOG 101 // 添加缺失的定义 #define IDC_MACHINE_CODE 1001 #define IDC_DAYS_COMBO 1002 #define IDC_REG_CODE 1003 #define IDC_GENERATE_BTN 1004 #define IDC_REGISTER_BTN 1005 #define IDC_STATUS_TEXT 1006 #define IDC_VALIDATE_BTN 1007 // 全局变量 HWND g_hMainDlg = NULL; char g_szMachineCode[256] = { 0 }; // 函数声明 const char* GetMachineCode(); const char* ComputeRegistration(const char* machineCode, int daysChoice); BOOL SaveRegistration(const char* machineCode, const char* regCode, int daysChoice); int ValidateLicense(); void UpdateStatus(const char* message); void InitializeControls(HWND hDlg); void GenerateRegistrationCode(HWND hDlg); void RegisterProduct(HWND hDlg); void ValidateLicenseOnStartup(); // 获取机器码函数 const char* GetMachineCode() { if (g_szMachineCode[0] != '\0') { return g_szMachineCode; } HRESULT hres; std::string serials; // 初始化COM hres = CoInitializeEx(0, COINIT_MULTITHREADED); if (FAILED(hres)) { return "COM Init Failed"; } // 设置COM安全级别 hres = CoInitializeSecurity( NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, NULL ); if (FAILED(hres)) { CoUninitialize(); return "CoInitializeSecurity Failed"; } // 创建WMI实例 IWbemLocator* pLoc = NULL; hres = CoCreateInstance( CLSID_WbemLocator, 0, CLSCTX_INPROC_SERVER, IID_IWbemLocator, (LPVOID*)&pLoc ); if (FAILED(hres)) { CoUninitialize(); return "WbemLocator Failed"; } // 连接到WMI IWbemServices* pSvc = NULL; hres = pLoc->ConnectServer( _bstr_t(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL, 0, 0, &pSvc ); if (FAILED(hres)) { pLoc->Release(); CoUninitialize(); return "ConnectServer Failed"; } // 设置代理安全级别 hres = CoSetProxyBlanket( pSvc, RPC_C_AUTHN_WINNT, RPC_C_AUTHZ_NONE, NULL, RPC_C_AUTHN_LEVEL_CALL, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE ); if (FAILED(hres)) { pSvc->Release(); pLoc->Release(); CoUninitialize(); return "SetProxyBlanket Failed"; } // 查询CPU信息 IEnumWbemClassObject* pEnumerator = NULL; hres = pSvc->ExecQuery( bstr_t("WQL"), bstr_t("SELECT * FROM Win32_Processor"), WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnumerator ); if (SUCCEEDED(hres)) { IWbemClassObject* pclsObj = NULL; ULONG uReturn = 0; while (pEnumerator) { HRESULT hr = pEnumerator->Next(WBEM_INFINITE, 1, &pclsObj, &uReturn); if (0 == uReturn) break; VARIANT vtProp; hr = pclsObj->Get(L"ProcessorId", 0, &vtProp, 0, 0); if (SUCCEEDED(hr)) { serials += _bstr_t(vtProp.bstrVal); VariantClear(&vtProp); } pclsObj->Release(); } pEnumerator->Release(); } // 查询磁盘信息 hres = pSvc->ExecQuery( bstr_t("WQL"), bstr_t("SELECT * FROM Win32_DiskDrive"), WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnumerator ); if (SUCCEEDED(hres)) { IWbemClassObject* pclsObj = NULL; ULONG uReturn = 0; while (pEnumerator) { HRESULT hr = pEnumerator->Next(WBEM_INFINITE, 1, &pclsObj, &uReturn); if (0 == uReturn) break; VARIANT vtProp; hr = pclsObj->Get(L"SerialNumber", 0, &vtProp, 0, 0); if (SUCCEEDED(hr)) { serials += _bstr_t(vtProp.bstrVal); VariantClear(&vtProp); } pclsObj->Release(); } pEnumerator->Release(); } // 清理资源 pSvc->Release(); pLoc->Release(); CoUninitialize(); // 生成哈希值 HCRYPTPROV hProv = 0; HCRYPTHASH hHash = 0; BYTE rgbHash[16]; DWORD cbHash = 16; CHAR rgbDigits[] = "0123456789abcdef"; if (!CryptAcquireContext(&hProv, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT)) { return "CryptoContext Failed"; } if (!CryptCreateHash(hProv, CALG_MD5, 0, 0, &hHash)) { CryptReleaseContext(hProv, 0); return "CreateHash Failed"; } if (!CryptHashData(hHash, (BYTE*)serials.c_str(), (DWORD)serials.length(), 0)) { CryptDestroyHash(hHash); CryptReleaseContext(hProv, 0); return "HashData Failed"; } if (!CryptGetHashParam(hHash, HP_HASHVAL, rgbHash, &cbHash, 0)) { CryptDestroyHash(hHash); CryptReleaseContext(hProv, 0); return "GetHashParam Failed"; } std::string hashStr; for (DWORD i = 0; i < cbHash; i++) { char rgb[3]; sprintf_s(rgb, 3, "%c%c", rgbDigits[rgbHash[i] >> 4], rgbDigits[rgbHash[i] & 0xf]); hashStr += rgb; } // 修正strcpy_s调用 strcpy_s(g_szMachineCode, sizeof(g_szMachineCode), hashStr.c_str()); return g_szMachineCode; } // 计算注册码函数 const char* ComputeRegistration(const char* machineCode, int daysChoice) { static char regBuffer[256] = { 0 }; std::string input = machineCode; std::string regCode; // 简单转换算法(实际应使用加密算法) for (char c : input) { regCode += (c + daysChoice) ^ 0xAA; } // 修正strcpy_s调用 strcpy_s(regBuffer, sizeof(regBuffer), regCode.c_str()); return regBuffer; } // 保存注册信息函数 BOOL SaveRegistration(const char* machineCode, const char* regCode, int daysChoice) { HKEY hKey; LPCSTR subKey = "Software\\MyApp\\Registration"; // 创建注册表项 if (RegCreateKeyExA(HKEY_CURRENT_USER, subKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey, NULL) != ERROR_SUCCESS) { return FALSE; } // 保存机器码 RegSetValueExA(hKey, "MachineCode", 0, REG_SZ, (const BYTE*)machineCode, (DWORD)strlen(machineCode) + 1); // 保存注册码 RegSetValueExA(hKey, "RegCode", 0, REG_SZ, (const BYTE*)regCode, (DWORD)strlen(regCode) + 1); // 保存授权天数 DWORD days = 0; switch (daysChoice) { case 0: days = 7; break; case 1: days = 15; break; case 2: days = 30; break; case 3: days = 0xFFFFFFFF; // 永久 } RegSetValueExA(hKey, "Days", 0, REG_DWORD, (const BYTE*)&days, sizeof(days)); // 保存激活日期 SYSTEMTIME st; GetSystemTime(&st); FILETIME ft; SystemTimeToFileTime(&st, &ft); RegSetValueExA(hKey, "ActivationDate", 0, REG_QWORD, (const BYTE*)&ft, sizeof(ft)); RegCloseKey(hKey); return TRUE; } // 验证授权函数 int ValidateLicense() { HKEY hKey; LPCSTR subKey = "Software\\MyApp\\Registration"; if (RegOpenKeyExA(HKEY_CURRENT_USER, subKey, 0, KEY_READ, &hKey) != ERROR_SUCCESS) { return -1; // 未注册 } // 检查机器码是否匹配 char storedMachineCode[256] = { 0 }; DWORD size = sizeof(storedMachineCode); if (RegQueryValueExA(hKey, "MachineCode", NULL, NULL, (LPBYTE)storedMachineCode, &size) != ERROR_SUCCESS) { RegCloseKey(hKey); return -1; } if (strcmp(storedMachineCode, GetMachineCode()) != 0) { RegCloseKey(hKey); return -1; // 机器码不匹配 } // 检查授权天数 DWORD days = 0; size = sizeof(days); if (RegQueryValueExA(hKey, "Days", NULL, NULL, (LPBYTE)&days, &size) != ERROR_SUCCESS) { RegCloseKey(hKey); return -1; } // 永久授权 if (days == 0xFFFFFFFF) { RegCloseKey(hKey); return 1; } // 检查激活日期 FILETIME activationDate; size = sizeof(activationDate); if (RegQueryValueExA(hKey, "ActivationDate", NULL, NULL, (LPBYTE)&activationDate, &size) != ERROR_SUCCESS) { RegCloseKey(hKey); return -1; } // 计算已过天数 SYSTEMTIME stNow; FILETIME ftNow; GetSystemTime(&stNow); SystemTimeToFileTime(&stNow, &ftNow); ULARGE_INTEGER uAct, uNow; uAct.LowPart = activationDate.dwLowDateTime; uAct.HighPart = activationDate.dwHighDateTime; uNow.LowPart = ftNow.dwLowDateTime; uNow.HighPart = ftNow.dwHighDateTime; // 100纳秒 = 1 tick, 1天 = 864000000000 ticks ULONGLONG diff = (uNow.QuadPart - uAct.QuadPart) / 864000000000; RegCloseKey(hKey); return (diff <= days) ? 1 : 0; // 1=有效, 0=过期 } // 对话框消息处理 INT_PTR CALLBACK DialogProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { switch (uMsg) { case WM_INITDIALOG: g_hMainDlg = hDlg; InitializeControls(hDlg); ValidateLicenseOnStartup(); return TRUE; case WM_COMMAND: switch (LOWORD(wParam)) { case IDC_GENERATE_BTN: GenerateRegistrationCode(hDlg); break; case IDC_REGISTER_BTN: RegisterProduct(hDlg); break; case IDC_VALIDATE_BTN: ValidateLicenseOnStartup(); break; case IDCANCEL: EndDialog(hDlg, 0); return TRUE; } break; } return FALSE; } // 初始化控件 void InitializeControls(HWND hDlg) { // 设置字体 HFONT hFont = CreateFont(14, 0, 0, 0, FW_NORMAL, FALSE, FALSE, FALSE, DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS, DEFAULT_QUALITY, DEFAULT_PITCH | FF_DONTCARE, L"Arial"); // 获取机器码并显示 const char* mc = GetMachineCode(); SetDlgItemTextA(hDlg, IDC_MACHINE_CODE, mc); // 设置控件字体 HWND hWnd = GetDlgItem(hDlg, IDC_MACHINE_CODE); SendMessage(hWnd, WM_SETFONT, (WPARAM)hFont, TRUE); hWnd = GetDlgItem(hDlg, IDC_REG_CODE); SendMessage(hWnd, WM_SETFONT, (WPARAM)hFont, TRUE); // 初始化授权天数下拉框 HWND hCombo = GetDlgItem(hDlg, IDC_DAYS_COMBO); SendMessageW(hCombo, CB_ADDSTRING, 0, (LPARAM)L"7天试用"); SendMessageW(hCombo, CB_ADDSTRING, 0, (LPARAM)L"15天试用"); SendMessageW(hCombo, CB_ADDSTRING, 0, (LPARAM)L"30天正式版"); SendMessageW(hCombo, CB_ADDSTRING, 0, (LPARAM)L"永久授权"); SendMessage(hCombo, CB_SETCURSEL, 3, 0); // 默认选择永久授权 // 设置状态文本 UpdateStatus("请选择授权类型并生成注册码"); } // 生成注册码 void GenerateRegistrationCode(HWND hDlg) { // 获取选择的授权天数 HWND hCombo = GetDlgItem(hDlg, IDC_DAYS_COMBO); int daysChoice = (int)SendMessage(hCombo, CB_GETCURSEL, 0, 0); // 计算注册码 const char* mc = GetMachineCode(); const char* regCode = ComputeRegistration(mc, daysChoice); // 显示注册码 SetDlgItemTextA(hDlg, IDC_REG_CODE, regCode); UpdateStatus("注册码已生成,点击注册按钮完成激活"); } // 注册产品 void RegisterProduct(HWND hDlg) { // 获取选择的授权天数 HWND hCombo = GetDlgItem(hDlg, IDC_DAYS_COMBO); int daysChoice = (int)SendMessage(hCombo, CB_GETCURSEL, 0, 0); // 获取注册码 char regCode[256] = { 0 }; GetDlgItemTextA(hDlg, IDC_REG_CODE, regCode, sizeof(regCode)); // 保存注册信息 const char* mc = GetMachineCode(); if (SaveRegistration(mc, regCode, daysChoice)) { UpdateStatus("产品注册成功!"); MessageBoxA(hDlg, "产品激活成功!", "注册成功", MB_OK | MB_ICONINFORMATION); } else { UpdateStatus("注册失败,请重试"); MessageBoxA(hDlg, "注册失败,请检查系统权限", "错误", MB_OK | MB_ICONERROR); } } // 验证授权 void ValidateLicenseOnStartup() { int status = ValidateLicense(); switch (status) { case 1: UpdateStatus("授权状态: 已激活 (有效授权)"); break; case 0: UpdateStatus("授权状态: 已过期 (请重新注册)"); break; case -1: UpdateStatus("授权状态: 未注册 (请激活产品)"); break; default: UpdateStatus("授权状态: 未知错误"); } } // 更新状态文本 void UpdateStatus(const char* message) { SetDlgItemTextA(g_hMainDlg, IDC_STATUS_TEXT, message); } // 主程序入口 int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) { // 初始化COM if (FAILED(CoInitializeEx(NULL, COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE))) { MessageBoxA(NULL, "COM初始化失败", "错误", MB_OK | MB_ICONERROR); return 1; } // 初始化通用控件 INITCOMMONCONTROLSEX icc; icc.dwSize = sizeof(icc); icc.dwICC = ICC_WIN95_CLASSES; InitCommonControlsEx(&icc); // 创建对话框 DialogBoxParam(hInstance, MAKEINTRESOURCE(IDD_MAIN_DIALOG), NULL, DialogProc, 0); // 清理COM CoUninitialize(); return 0; } [NK201!无法解析的外部符号 main,函数 "int cdecl invoke main(void)"(?invoke main@@YAHXZ)中引用了该符号 LNK112(1 个无法解析的外部命令

filetype

#include "pch.h" #include <Windows.h> #include <Wbemidl.h> #include <comdef.h> #include <WinCrypt.h> #include <string> #include <algorithm> #include <sstream> #include <vector> #pragma comment(lib, "wbemuuid.lib") #pragma comment(lib, "Advapi32.lib") #pragma comment(lib, "Crypt32.lib") // 导出函数声明 extern "C" __declspec(dllexport) const char* GetMachineCode(); extern "C" __declspec(dllexport) const char* ComputeRegistration(const char* machineCode, int daysChoice); extern "C" __declspec(dllexport) BOOL SaveRegistration(const char* machineCode, const char* regCode, int daysChoice); extern "C" __declspec(dllexport) int ValidateLicense(); // 全局缓冲区用于返回字符串 thread_local static char g_buffer[256] = { 0 }; // 获取机器码函数 const char* GetMachineCode() { HRESULT hres; std::string serials; // 初始化COM hres = CoInitializeEx(0, COINIT_MULTITHREADED); if (FAILED(hres)) { strcpy_s(g_buffer, "COM Init Failed"); return g_buffer; } // 设置安全级别 hres = CoInitializeSecurity( NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, NULL ); if (FAILED(hres)) { CoUninitialize(); strcpy_s(g_buffer, "Security Init Failed"); return g_buffer; } // 创建WMI实例 IWbemLocator* pLoc = NULL; hres = CoCreateInstance( CLSID_WbemLocator, 0, CLSCTX_INPROC_SERVER, IID_IWbemLocator, (LPVOID*)&pLoc ); if (FAILED(hres)) { CoUninitialize(); strcpy_s(g_buffer, "WMI Locator Failed"); return g_buffer; } // 连接WMI IWbemServices* pSvc = NULL; hres = pLoc->ConnectServer( _bstr_t(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL, 0, 0, &pSvc ); if (FAILED(hres)) { pLoc->Release(); CoUninitialize(); strcpy_s(g_buffer, "WMI Connect Failed"); return g_buffer; } // 设置代理安全 hres = CoSetProxyBlanket( pSvc, RPC_C_AUTHN_WINNT, RPC_C_AUTHZ_NONE, NULL, RPC_C_AUTHN_LEVEL_CALL, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE ); if (FAILED(hres)) { pSvc->Release(); pLoc->Release(); CoUninitialize(); strcpy_s(g_buffer, "Proxy Setup Failed"); return g_buffer; } // 执行查询 IEnumWbemClassObject* pEnumerator = NULL; hres = pSvc->ExecQuery( bstr_t("WQL"), bstr_t("SELECT SerialNumber FROM Win32_DiskDrive"), WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnumerator ); if (FAILED(hres)) { pSvc->Release(); pLoc->Release(); CoUninitialize(); strcpy_s(g_buffer, "Query Failed"); return g_buffer; } // 处理查询结果 IWbemClassObject* pclsObj = NULL; ULONG uReturn = 0; while (pEnumerator) { HRESULT hr = pEnumerator->Next(WBEM_INFINITE, 1, &pclsObj, &uReturn); if (uReturn == 0) break; VARIANT vtProp; VariantInit(&vtProp); // 获取序列号 hr = pclsObj->Get(L"SerialNumber", 0, &vtProp, 0, 0); if (SUCCEEDED(hr) && vtProp.vt == VT_BSTR) { _bstr_t bstr(vtProp.bstrVal); serials += (const char*)bstr; } VariantClear(&vtProp); pclsObj->Release(); } // 清理资源 pEnumerator->Release(); pSvc->Release(); pLoc->Release(); CoUninitialize(); // 计算MD5哈希 HCRYPTPROV hProv = 0; HCRYPTHASH hHash = 0; BYTE rgbHash[16]; DWORD cbHash = 16; CHAR rgbDigits[] = "0123456789abcdef"; if (!CryptAcquireContext(&hProv, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT)) { strcpy_s(g_buffer, "Crypto Context Failed"); return g_buffer; } if (!CryptCreateHash(hProv, CALG_MD5, 0, 0, &hHash)) { CryptReleaseContext(hProv, 0); strcpy_s(g_buffer, "Hash Creation Failed"); return g_buffer; } if (!CryptHashData(hHash, (BYTE*)serials.c_str(), (DWORD)serials.length(), 0)) { CryptDestroyHash(hHash); CryptReleaseContext(hProv, 0); strcpy_s(g_buffer, "Hashing Failed"); return g_buffer; } if (CryptGetHashParam(hHash, HP_HASHVAL, rgbHash, &cbHash, 0)) { std::string hashStr; for (DWORD i = 0; i < cbHash; i++) { char hex[3]; sprintf_s(hex, "%02x", rgbHash[i]); hashStr += hex; } strcpy_s(g_buffer, hashStr.c_str()); } else { strcpy_s(g_buffer, "Hash Retrieval Failed"); } CryptDestroyHash(hHash); CryptReleaseContext(hProv, 0); return g_buffer; } // 计算注册码 const char* ComputeRegistration(const char* machineCode, int daysChoice) { int days; switch (daysChoice) { case 0: days = 7; break; case 1: days = 15; break; case 2: days = 30; break; default: days = 9999; // 永久 } std::string mc(machineCode); if (mc.length() < 5) { strcpy_s(g_buffer, "Invalid Machine Code"); return g_buffer; } // 算法:前4字符 + (第5字符ASCII+天数) + 反转字符前4 + 天数*100 std::string part1 = mc.substr(0, 4); char c = mc[4]; std::string part2 = std::to_string(static_cast<int>(c) + days); std::string reversed = mc; std::reverse(reversed.begin(), reversed.end()); std::string part3 = reversed.substr(0, 4); std::string part4 = std::to_string(days * 100); std::string regCode = part1 + part2 + part3 + part4; strcpy_s(g_buffer, regCode.c_str()); return g_buffer; } // 保存注册信息 BOOL SaveRegistration(const char* machineCode, const char* regCode, int daysChoice) { HKEY hKey; std::string subkey = "Software\\MyPlugin\\"; subkey += machineCode; // 创建注册表项 if (RegCreateKeyExA( HKEY_CURRENT_USER, subkey.c_str(), 0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hKey, NULL) != ERROR_SUCCESS) { return FALSE; } // 写入注册码 if (RegSetValueExA( hKey, "Registration", 0, REG_SZ, (const BYTE*)regCode, (DWORD)strlen(regCode) + 1) != ERROR_SUCCESS) { RegCloseKey(hKey); return FALSE; } // 写入天数选项 std::string daysStr = std::to_string(daysChoice); if (RegSetValueExA( hKey, "ExpireDays", 0, REG_SZ, (const BYTE*)daysStr.c_str(), (DWORD)daysStr.length() + 1) != ERROR_SUCCESS) { RegCloseKey(hKey); return FALSE; } // 写入注册日期 (使用系统时间) SYSTEMTIME st; GetLocalTime(&st); char dateStr[32]; sprintf_s(dateStr, "%04d%02d%02d%02d%02d%02d", st.wYear, st.wMonth, st.wDay, st.wHour, st.wMinute, st.wSecond); if (RegSetValueExA( hKey, "RegisterDate", 0, REG_SZ, (const BYTE*)dateStr, (DWORD)strlen(dateStr) + 1) != ERROR_SUCCESS) { RegCloseKey(hKey); return FALSE; } RegCloseKey(hKey); return TRUE; } // 验证授权 int ValidateLicense() { const char* machineCode = GetMachineCode(); if (!machineCode || strlen(machineCode) == 0) { return 0; // 获取机器码失败 } std::string subkey = "Software\\MyPlugin\\"; subkey += machineCode; HKEY hKey; if (RegOpenKeyExA( HKEY_CURRENT_USER, subkey.c_str(), 0, KEY_READ, &hKey) != ERROR_SUCCESS) { return -1; // 未注册 } // 读取注册信息 char regDate[32] = { 0 }; DWORD size = sizeof(regDate); if (RegQueryValueExA( hKey, "RegisterDate", NULL, NULL, (LPBYTE)regDate, &size) != ERROR_SUCCESS) { RegCloseKey(hKey); return -1; } char daysChoice[10] = { 0 }; size = sizeof(daysChoice); if (RegQueryValueExA( hKey, "ExpireDays", NULL, NULL, (LPBYTE)daysChoice, &size) != ERROR_SUCCESS) { RegCloseKey(hKey); return -1; } RegCloseKey(hKey); // 解析注册日期 int year, month, day, hour, min, sec; if (sscanf_s(regDate, "%4d%2d%2d%2d%2d%2d", &year, &month, &day, &hour, &min, &sec) != 6) { return -1; } // 计算已过天数 SYSTEMTIME regTime = { 0 }; regTime.wYear = year; regTime.wMonth = month; regTime.wDay = day; FILETIME ftReg, ftNow; SystemTimeToFileTime(®Time, &ftReg); GetSystemTimeAsFileTime(&ftNow); ULARGE_INTEGER ulReg, ulNow; ulReg.LowPart = ftReg.dwLowDateTime; ulReg.HighPart = ftReg.dwHighDateTime; ulNow.LowPart = ftNow.dwLowDateTime; ulNow.HighPart = ftNow.dwHighDateTime; ULONGLONG diff = ulNow.QuadPart - ulReg.QuadPart; int daysPassed = static_cast<int>(diff / (10000000ULL * 60 * 60 * 24)); // 检查授权状态 int choice = atoi(daysChoice); if (choice == 3) return 1; // 永久授权 int maxDays = 0; switch (choice) { case 0: maxDays = 7; break; case 1: maxDays = 15; break; case 2: maxDays = 30; break; default: return 0; } return (daysPassed <= maxDays) ? 1 : 0; } 生成的dll如何使用

Jeffrey_Martin
  • 粉丝: 0
上传资源 快速赚钱