VMProtect是一种很可靠的工具,可以保护应用程序代码免受分析和破解,但只有在应用程序内保护机制正确构建且没有可能破坏整个保护的严重错误的情况下,才能实现最好的效果。
建筑保护总是经历两个主要步骤:开发和发布。至于许可,首先创建一个应用程序,将保护集成到其中,然后添加检查和功能限制。只有经过全面测试,才能将产品提供给用户并开始第二阶段。测试受保护的应用程序是一个复杂的过程,因为需要确保所有检查和条件跳转都能正常运行。
许可系统提供“开发者模式”(AKA“测试模式”),在此工作模式下,不对应用程序应用任何保护,并且在配置文件中调整系统对提供的序列号的反应。当应用程序没有错误并且它正确地与许可系统一起使用时,VMProtect将“测试”许可模块替换为执行实际序列号检查的真实模块。
测试模式
在测试模式中,许可系统(它返回的状态和数据)对提供的序列号的所有反应都在配置文件中描述。该文件名为VMPLicense.ini,应位于应用程序的工作文件夹中。在下面提供的10个步骤中,将从创建最简单的应用程序到在测试模式下全面使用许可系统,具有硬件锁定和限制免费升级的时间。
▲步骤八:黑名单中的序列号
许可系统不应接受VMProtect中标记为“已阻止”的序列号。下次重新构建应用程序时,VMProtect会将列入黑名单的序列号的哈希添加到受保护的应用程序。结果,该应用程序的许可系统将来会拒绝这些序列号。
首先,让最小化main()函数的内容:
int main(int argc,char ** argv) { char * serial =“ Xserialnumber”; //为了简单起见,我们直接在代码中设置序列号 int res = VMProtectSetSerialNumber(序列); print_state(res); 返回0; }
在测试模式下,许可系统将今天视为构建日期,因此,必须通过此行中指定的日期,这一点很重要。即,最大日期是昨天。修改main()函数的代码,使其如下所示:
然后,运行程序并确保许可系统确实接受我们的序列号:
state = 0
现在,将此序列号添加到许可系统的黑名单中。将以下行添加到ini文件中:
BlackListedSerialNumber = Xserialnumber
再次运行该程序:
state = SERIAL_STATE_FLAG_BLACKLISTED
我们是否应该通知用户他或她输入的序列号被列入黑名单?它是由你决定。您可以简单地告诉序列号不正确,也可以通知用户密钥已被盗用。许可系统仅将使用黑名单序列号的事实告知程序。