logo VMProtect用户手册 我也要发布文档

将VMProtect集成到应用程序教程:许可API函数


VMProtect是一种很可靠的工具,可以保护应用程序代码免受分析和破解,但只有在应用程序内保护机制正确构建且没有可能破坏整个保护的严重错误的情况下,才能实现最好的效果。

本文介绍许可API函数的相关内容。

免费下载VMProtect体验版 优惠购买VMProtect正式版




许可系统API是VMProtect API及其SDK的组成部分。使用API可以指定序列号并检索有关它的所有信息,包括是否适合该程序、序列号是否已过期、该产品注册到的名称等等。同样,API提供了程序在其上运行的计算机的硬件标识符。

VMProtectSetSerialNumber

此函数将序列号加载到许可系统。调用语法:

int VMProtectSetSerialNumber(const char * SerialNumber);
输入的SerialNumber参数必须包含一个指向以null结尾的字符串('\ 0')的指针,该字符串包含以64为基数的序列号。该函数返回序列号状态标志的位掩码,与VMProtectGetSerialNumberState()返回的掩码相同。您可以在下面阅读有关标志的更多信息。如果函数返回0,则序列号为“good”。

VMProtectGetSerialNumberState

此函数返回通过调用VMProtectSetSerialNumber()指定的序列号的状态标志。

int VMProtectGetSerialNumberState();
如果至少设置了一个标志,则序列号有问题。如果设置了至少一位,该程序将无法运行。下表列出了标志及其值的详细说明:

Flag
描述
SERIAL_STATE_FLAG_CORRUPTED
0×00000001
许可系统已损坏。原因可能是:保护项目的设置错误,尝试破解。
SERIAL_STATE_FLAG_INVALID
0×00000002
序列号不正确。如果许可系统无法解密序列号,则设置该标志。
SERIAL_STATE_FLAG_BLACKLISTED
0×00000004
序列号与产品匹配,但在VMProtect中列为黑色。
SERIAL_STATE_FLAG_DATE_EXPIRED
0×00000008
序列号已过期。可通过调用VMProtectGetSerialNumberData()获得有关到期日期的详细信息。
SERIAL_STATE_FLAG_RUNNING_TIME_OVER
0×00000010
该程序的运行时间已用完。您可以通过调用VMProtectGetSerialNumberData()获得有关程序运行时间的详细信息。
SERIAL_STATE_FLAG_BAD_HWID
0×00000020
硬件标识符与密钥中指定的硬件标识符不匹配。
SERIAL_STATE_FLAG_MAX_BUILD_EXPIRED
0×00000040
序列号与受保护程序的当前版本不匹配。可通过调用VMProtectGetSerialNumberData()获得此序列号匹配的程序的最大构建日期。
VMProtectGetSerialNumberData

此函数获取有关通过调用VMProtectSetSerialNumber()获得的序列号内容的信息。调用语法:

bool VMProtectGetSerialNumberData(VMProtectSerialNumberData * Data,int Size);
第一个参数是指向VMProtectSerialNumberData结构的指针,将在其中写入所有必要的信息。第二个参数是第一个参数中传递的结构的大小。需要控制结构的格式。如果许可系统已损坏(请参见SERIAL_STATE_FLAG_CORRUPTED标志)、提供的结构地址为零或传递的结构大小不正确,则该函数返回FALSE。在其他情况下,该函数返回TRUE,并将有关序列号的所有信息记录到提供的地址中。以下是该结构的要素:

元素 类型 描述
nState
int
指示密钥状态的位标志掩码。与VMProtectGetSerialNumberState()返回的类似。
wUserName
wchar_t[256]
UNICODE中的客户名称,以空值结尾。
wEMail
wchar_t[256]
客户使用UNICODE的电子邮件,以零结尾。
dtExpire
VMProtectDate
密钥到期日期。VMProtectDate结构的格式如下所述。
dtMaxBuild
VMProtectDate
给定密钥可以使用的最大产品生产日期。VMProtectDate结构的格式如下所述。
bRunningTime
int
该程序将运行的分钟数(一个会话的最长持续时间)。以分钟为单位的值,从程序启动时算起。
nUserDataLength
unsigned char
bUserData字段中用户数据的长度。
bUserData

unsigned

char[255]

用户数据放入密钥中。实际的字节数在nUserDataLength中指定。
VMProtectDate结构是一个紧凑的日期表示。其字段如下表所示:

元素 类型 描述
wYear
无符号短
bMonth
无符号字符
月份,从1开始
bDay
无符号字符
天,从1开始
VMProtectGetCurrentHWID
该功能获取程序正在运行的PC的硬件标识符。调用语法:

int VMProtectGetCurrentHWID(char * HWID,int大小);
第一个参数是指向写入标识符的存储区的指针。第二个参数是该区域的大小。该函数返回写入的字节数,包括尾随的零字节('\ 0')。如果第一个参数中提供了NULL,则该函数返回存储硬件标识符所需的字节数。下面是使用该函数的正确方法:
int nSize = VMProtectGetCurrentHWID(NULL, 0); // get the required buffer size
char *pBuf = new char[nSize]; // allocate memory for the buffer
VMProtectGetCurrentHWID(pBuf, nSize); // obtain the identifier
// use the identifier
delete [] pBuf; // release memory



有关 VMProtect 更多资源,请联系【慧都客服】了解

双“旦”狂欢钜惠,领优惠券购VMProtect享折上折>>>