Java:使用CTR模式的AES加密;无法解密

时间:2013-01-15 13:43:46

标签: java encryption aes

我正在使用以下代码,但它没有正确解密文本,我得到的是输出

加密:%öNo2F?¢¶SHºûÅ“?¾

明文:你好×amoriginÎl

public static void main(String[] args) throws Exception {
    // TODO Auto-generated method stub

    // Dernier exemple CTR mode
    // Clé 16 bits
    byte[] keyBytes = new byte[] { (byte) 0x36, (byte) 0xf1, (byte) 0x83,
            (byte) 0x57, (byte) 0xbe, (byte) 0x4d, (byte) 0xbd,
            (byte) 0x77, (byte) 0xf0, (byte) 0x50, (byte) 0x51,
            (byte) 0x5c, 0x73, (byte) 0xfc, (byte) 0xf9, (byte) 0xf2 };
    // IV 16 bits (préfixe du cipherText)
    byte[] ivBytes = new byte[] { (byte) 0x69, (byte) 0xdd, (byte) 0xa8,
            (byte) 0x45, (byte) 0x5c, (byte) 0x7d, (byte) 0xd4,
            (byte) 0x25, (byte) 0x4b, (byte) 0xf3, (byte) 0x53,
            (byte) 0xb7, (byte) 0x73, (byte) 0x30, (byte) 0x4e, (byte) 0xec };

    // Initialisation
    SecretKeySpec key = new SecretKeySpec(keyBytes, "AES");
    IvParameterSpec ivSpec = new IvParameterSpec(ivBytes);

    // Mode
    Cipher cipher = Cipher.getInstance("AES/CTR/NoPadding");

    String originalText = "hello i am original";
    // ///////////////////////////////ENCRYPTING
    cipher.init(Cipher.ENCRYPT_MODE, key, ivSpec);
    byte[] ciphered = cipher.doFinal(originalText.getBytes());
    String cipherText = new String(ciphered,"UTF-8");
    System.out.println("ciphered: " + cipherText);
    // ///////////////////////////////DECRYPTING
    cipher = Cipher.getInstance("AES/CTR/NoPadding");

    cipher.**init(Cipher.DECRYPT_MODE**, key, ivSpec);
    byte[] plain = **cipher.doFinal(ciphered);**
    originalText = new String(plain,"UTF-8");
    System.out.println("plaintext: " + originalText);
}

我无法弄清楚我做错了什么。非常感谢任何帮助。 也是这种加密一些数据的正确方法,这次我试图加密4byte城市密码。 提前谢谢

////

我做了那些改变,但它工作得很好但是如果我通过则会出现什么问题  cipher.init()函数中的cipherText.getByte()。像

byte[] plain = cipher.doFinal(cipherText.getByte("UTF-8"));

n'谢谢你的帮助。

2 个答案:

答案 0 :(得分:5)

对于解密,您需要在DECRYPT_MODE中初始化密码。并且byte []到String转换也不正确(参见其他答案)。

答案 1 :(得分:2)

您不能将加密的字节转换为类似的字符串。 “bytes”和“chars”是两个完全不同的东西。删除将字节转换为字符串并在加密和解密之间再次返回的代码,并且您的代码应该正常工作(如其他答案中所指出的,第二步应该使用DECRYPT_MODE)。

请注意,在使用平台字符编码在字节和字符/字符串之间进行转换时需要注意,因为在不同平台上这可能会有所不同。如果您的数据需要跨平台移动,这可能会导致问题。如果您的默认平台编码不支持您正在使用的文本中的所有字符,它也可能是有损的。