C#与JAVA等价的3DES加密方法 CFB加密模式

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);
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值