最近想把某个C#的项目替换成易语言来写。涉及到一个DES加密解密的问题。
打开易一看,哇,它直接自带(或者是精易模块带的)有加密函数。
字节集到十六进制文本 (AES_DES_算法 (#对称算法_DES_CBC, 到字节集 (“test”), 到字节集 (“myprivatekey”), 真))
但是对比后发现这样加密出来的字符串与之前C#的对不上。
查了下原来自己用的C#的版本,它的IV偏移量参数是用的密钥。但易自带的这个写死了。IV偏移量不是一个参数。
不过网上新找了个易的源码,可以实现DES加解密功能。尝试将它的代码迁移到自己的项目时又发现报错“没有您输入的算法,请检查算法参数,或者升级到最新openssl”
想着函数都已经迁移了,为何和原例子不一样的结果呢?
仔细追查,才终于知道原例子在窗体启动时,使用相关算法时,有先初始化加载的。
.版本 2
OpenSSL_add_all_ciphers ()
' OpenSSL_add_all_ciphers ()这个函数是加载所有支持的算法,如果要使用对称加密(AES EDS 3DES),则必须在软件启动的时候加载一下所有的算法
' 如果在生成PEM文件的时候要生成一个有密码的PEM文件,也要先加载算法
知道原因后,在自己的代码上使用加密前先调用一下上面这句,就OK了。