你是对的:为了安全起见,你需要为每条消息使用一个新的、随机的 IV。这意味着您要么需要重新创建密码,要么自己为每条后续消息随机设置 IV。前者可能更安全,因为如果您更改密码或模式,可能还需要随机设置一些其他状态,并且重新初始化密码应该可以处理所有这些。
如果您不这样做,您最终会遇到 SSL 与 IV重用相同的相当糟糕的错误。
Cipher.doFinal 不会将密码重置为随机 IV。事实上,它比这更糟糕,它似乎将内部状态重置为您开始使用的相同 IV。如这段代码所示。
Cipher f = Cipher.getInstance("AES/CBC/PKCS5Padding");
byte[] keyBytes = new byte[] { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09,
0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f };
SecretKeySpec key = new SecretKeySpec(keyBytes, "AES");
f.init(Cipher.ENCRYPT_MODE, key);
byte[] iv = f.getIV();
System.out.println(Arrays.toString(f.doFinal("hello".getBytes())));
System.out.println(Arrays.toString(f.getIV()));
System.out.println(Arrays.toString(f.doFinal("hello".getBytes())));
System.out.println(Arrays.toString(f.getIV()));
System.out.println( Arrays.equals(f.getIV(), iv)); // true