在使用虚拟机保护软件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资源、优惠活动,请点击【客服】了解

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