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

许可系统API是VMProtect API及其SDK的组成部分。使用API可以指定序列号并检索有关它的所有信息,包括是否适合该程序、序列号是否已过期、该产品注册到的名称等等。


许可系统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 sizechar *pBuf = new char[nSize]; // allocate memory for the bufferVMProtectGetCurrentHWID(pBuf, nSize); // obtain the identifier// use the identifierdelete [] pBuf; // release memory


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

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

来源:慧都

声明:本站部分文章及图片转载于互联网,内容版权归原作者所有,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2020年1月1日
下一篇 2020年1月1日

相关推荐

发表回复

登录后才能评论