Linux下的 openssl 命令解密
我们以在线加密网站为例 http://tool.chacuo.net/cryptdes
我们选择des cbc模式,密钥为abcdefgh, 偏移量为12345678,以base64输出结果 对hello进行加密,得到结果8Snw+/EmQdY=
我们再用将在线网站改用shell命令 进行相同加密
echo -n 'hello' | openssl enc -des-cbc -K 'abcdefgh' -iv '12345678' -a
shell 提示key必须是16进制数,我们将密钥和向量都转为16进制再加密一下
echo -n 'hello' | openssl enc -des-cbc -K '6162636465666768' -iv '3132333435363738' -a
得到正确结果
openssl 命令中 -a可以把解密结果转为base64输出,那么需要hex输出则可以使用xxd 命令,如:
key=`echo -n abcdefgh | xxd -ps`;iv=`echo -n 12345678 | xxd -ps`; echo -n hello | openssl enc -des-cbc -K $key -iv $iv | xxd -pss