我正在另一个Java项目中的项目中实现加密。
java项目中的代码是这样的:
public static String cifraDES(String chave, String dado) throws Exception {
DESKeySpec keySpec = new DESKeySpec(hexStringToByteArray(chave));
SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
SecretKey passwordKey = kf.generateSecret(keySpec);
Cipher c = Cipher.getInstance("DES");
c = Cipher.getInstance("DES/ECB/NoPadding");
c.init(Cipher.ENCRYPT_MODE, passwordKey);
return bytesToHex(c.doFinal(hexStringToByteArray(dado)));
}
在 Ruby 项目中,我也想实现这个加密。但这不起作用:
dado = "53495A45303030386E6F7661313031305858585858585858"
chave = "3455189635541968"
des = OpenSSL::Cipher.new('des-ecb').encrypt
des.key = chave
s = des.update(dado) + des.final
Base64.encode64(s).gsub(/n/, "")
在终端中,我收到此消息:
'key' be must 8 bytes
我需要这个回报:b42e3dbfffd4bb5487a27fd702f079e287e6325767bfdd20
视图:http://des.online-domain-tools.com/link/1145159gOjlrPNRkaT/
您尚未从十六进制字符串转换密钥和数据,您可以使用 pack
来执行此操作:
dado = ["53495A45303030386E6F7661313031305858585858585858"].pack('H*')
(当您对密钥执行此操作时,它会从 16 个十六进制字符转换为 8 个字节,因此不执行此步骤会导致错误(。
您尚未指定无填充:
des.padding = 0
并且您希望结果十六进制编码,而不是基数 64。您可以使用unpack
:
puts s.unpack('H*')[0]
把所有的东西放在一起:
dado = ["53495A45303030386E6F7661313031305858585858585858"].pack('H*')
chave = ["3455189635541968"].pack('H*')
des = OpenSSL::Cipher.new('des-ecb').encrypt
des.key = chave
des.padding = 0
s = des.update(dado) + des.final
puts s.unpack('H*')[0]
结果是 b42e3dbfffd4bb5487a27fd702f079e287e6325767bfdd20
。
这个错误对我来说似乎很清楚。您chave
使用的密钥为 16 个字节。 您的密钥必须是 8 个字节。 因此,将密钥的长度减少到 8 个字符,然后尝试。