C#版:
public static string Encrypt3DES(string strString, string key, string iv)
{
TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider();
DES.Key = Encoding.UTF8.GetBytes(key);
DES.Mode = CipherMode.CFB;
DES.IV = Encoding.UTF8.GetBytes(iv);
ICryptoTransform DESEncrypt = DES.CreateEncryptor();
byte[] Buffer = Encoding.UTF8.GetBytes(strString);
return Convert.ToBase64String(DESEncrypt.TransformFinalBlock(Buffer, 0, Buffer.Length));
}
JAVA版:(注意:使用 CFB
和 OFB
之类的模式,Cipher 块可以加密单元中小于该 Cipher 的实际块大小的数据。请求这样一个模式时,可以指定一次处理的位数(可选):将此数添加到模式名称中,正如 "DES/CFB8/NoPadding
" 和 "DES/OFB32/PKCS5Padding
" 转换所示。如果未指定该数,则将使用特定于提供者的默认值。(例如,SunJCE 提供者对 DES 使用默认的 64 位)。因此,通过使用如 CFB8 或 OFB8 的 8 位模式,Cipher 块可以被转换为面向字节的 Cipher 流。)
public static String des3EncodeCFB(String key, String iv, String data) throws Exception {
return new BASE64Encoder().encode(des3Encode(key.getBytes(), iv.getBytes(), data.getBytes("UTF-8")));
}
/**
* CFB加密
*
* @param key 密钥
* @param keyiv IV
* @param data 明文
* @return Base64编码的密文
* @throws Exception
*/
public static byte[] des3Encode(byte[] key, byte[] keyiv, byte[] data) throws Exception {
DESedeKeySpec spec = new DESedeKeySpec(key);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
SecretKey deskey = keyFactory.generateSecret(spec);
IvParameterSpec ips = new IvParameterSpec(keyiv);
Cipher cipher = Cipher.getInstance("DESede/CFB8/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, deskey, ips);
return cipher.doFinal(data);
}