import javax.crypto.Cipher;
public abstract class Crypto {
private static final String CIPHER_ALGORITHM = "AES/CTR/NoPadding";
private String AesKeyString = "ByWelFHCgFqivFZrWs89LQ==";
private void setKey() throws NoSuchAlgorithmException{
byte[] keyBytes;
keyBytes = Base64.getDecoder().decode(AesKeyString);
aesKey = new SecretKeySpec(keyBytes, "AES");
}
protected byte[] execute(int mode, byte[] target, byte[] iv)
throws Exception{
Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);
IvParameterSpec ivSpec = new IvParameterSpec(iv);
cipher.init(mode, aesKey, ivSpec);
return cipher.doFinal(target);
}
}
根据NIST 建议- 附录 B,构造初始计数器块有两种有效方法(AES 是 128 位块密码):
- 128 位随机数与m位计数器值(通常为 32 位)进行异或。
- 64 位随机数附加到 64 位计数器。
我的问题是:
- 关于 javax.crypto.Cipher 的“ AES/CTR/NoPadding ”实例中使用的初始计数器块的确切过程是什么(假设 SunJCE 作为提供者)?也就是说,给定上面的代码,如果有的话,使用了之前的初始计数器块方法中的哪一种?