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