软件保护工具VMProtect将许可系统集成到应用程序(8):硬件锁定

在使用虚拟机保护软件VMProtect将许可系统集成到应用程序过程中,首先要接收硬件标识符,并将其传递给许可系统。当许可系统检测到标识符与序列 中的标识符一致后,才能进行后续步骤。

 

建筑保护总是经历两个主要步骤:开发和发布。至于许可,首先创建一个应用程序,将保护集成到其中,然后添加检查和功能限制。只有经过全面测试,才能将产品提供给用户并开始第二阶段。测试受保护的应用程序是一个复杂的过程,因为需要确保所有检查和条件跳转都能正常运行。

许可系统提供“开发者模式”(AKA“测试模式”),在此工作模式下,不对应用程序应用任何保护,并且在配置文件中调整系统对提供的序列 的反应。当应用程序没有错误并且它正确地与许可系统一起使用时,VMProtect将“测试”许可模块替换为执行实际序列 检查的真实模块。


接收硬件标识符

在锁定硬件之前,必须接收硬件的标识符,然后将标识符放入序列 中。因为将其传递给许可系统时,将检查标识符是否匹配。首先,将main()函数减少到最低限度:

int main(int argc,char ** argv){         int nSize = VMProtectGetCurrentHWID(NULL,0);         char * buf =新的char [nSize];         VMProtectGetCurrentHWID(buf,nSize);         printf(“ HWID:%s  n”,buf);         删除[] buf;         返回0; }

通过运行程序,将会收到一个默认的测试硬件标识符:

HWID:myhwid

将以下行添加到ini文件中可更改标识符:

MyHWID = test

当我们事后运行程序时可以看到,系统认为“test”是PC的硬件标识符:

HWID:测试

注意:该程序仅在使用VMProtect处理后才显示真实的硬件标识符。

硬件锁定序列

要将测试序列 锁定到硬件,应该在ini文件中再增加一行。这次,我们定义“put into”序列 的标识符:

KeyHWID = test

然后,使main()复杂一点。它将传递一个序列 并分析其获得的结果:

int main(int argc,char ** argv){         int nSize = VMProtectGetCurrentHWID(NULL,0);         char * buf =新的char [nSize];         VMProtectGetCurrentHWID(buf,nSize);         printf(“ HWID:%s  n”,buf);         删除[] buf;                 char * serial =“ Xserialnumber”;         int res = VMProtectSetSerialNumber(序列);         print_state(res);         返回0; }

运行代码后,将看到以下结果:

HWID:测试状态= 0

许可系统已将当前的硬件标识符与序列 中的标识符进行了比较。标识符相等,因此VMProtectSetSerialNumber()函数返回0 –序列 匹配。

现在,让我们尝试在另一个硬件上“运行”程序:只需将ini文件中MyHWID参数的值从“test”更改为“new test”,然后再次运行程序:

HWID: new teststate = SERIAL_STATE_FLAG_BAD_HWID

这一次,许可系统返回了SERIAL_STATE_FLAG_BAD_HWID标志,这意味着真实的硬件标识符与序列 中存储的标识符不匹配。

我们在屏幕上看到的当前标识符为“new test”,而序列 为“test”。如果将ini文件中的KeyHWID参数更改为“new test”,也可以让序列 在该“hardware”上运行。

— 未完待续 —


更多VMProtect资源、优惠活动,请点击【客服】了解

软件保护工具VMProtect将许可系统集成到应用程序(8):硬件锁定

标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2019年10月2日
下一篇 2019年10月2日

相关推荐

发表回复

登录后才能评论