软件的授权一般用到RSA算法,即外部授权码为公钥加密数据,而软件中有个唯一的私钥,对密文进行解密后,获得合法授权和使用,这种方法来源于RSA的不可攻破性。
先下载openssl 1.1.1的source code,然后按照上一篇介绍的compile方法编译出lib和include等,然后添加到VC++的项目include、lib目录中,然后在cmd命令行下完成密钥生成(私钥可以写入软件中)、数据文件加密(公钥加密短数据获得授权码密文)等操作,再在软件中使用openssl的私钥解密函数把密文解开。如下:
openssl genrsa -out prikey.pem 2048
openssl rsa -in prikey.pem -pubout -out pubkey.pem
openssl rsautl -encrypt -inkey pubkey.pem -pubin -in aaa.txt -out bbb.enc
openssl rsautl -decrypt -inkey prikey.pem -in bbb.enc > ccc.txt
将privatekey和publickey导出到相应的pem文件中,其中1024、2048、4096位密钥长度,单位bit,对应的加密后的密文长度就分别为0x80、0x100、0x200即128、256、512byte,x8后为bit长度即密钥长度。
在VC++代码中,可以使用如下代码段对数据进行加密,但是被加密长度限定为4,如1234,有时间可