解密由 加密的字节.NET的RijndaelManaged using Java

本文关键字:RijndaelManaged using Java NET 字节 加密 解密 | 更新日期: 2023-09-27 17:57:06

我正在尝试解密一些东西,这些东西是使用.NET/C#的RijndaelManage加密的,使用Java解密。

C# 程序不是我的;我无法将其更改为更具互操作性。但我知道它是如何加密的:

byte[] bytes = new UnicodeEncoding().GetBytes(password); // edit: built-in is 8chars
FileStream fileStream = new FileStream(outputFile, FileMode.Create);
RijndaelManaged rijndaelManaged = new RijndaelManaged();
CryptoStream cryptoStream = new CryptoStream((Stream) fileStream,
    rijndaelManaged.CreateEncryptor(bytes, bytes), CryptoStreamMode.Write);

我不知道如何在 Java 端解密它。我发现的最有用的东西是这篇博文,但它对实际细节很轻,我无法实现解密器。

编辑:我是个白痴,现在让它工作了。

UnicodeEncoding 是 UTF-16LE,而我使用的是 UTF-8。插入密码时切换到正确的编码已修复程序。

我还需要获得BouncyCastle并做Cipher.getInstance("AES/CBC/PKCS7Padding", "BC");

finaledit:以下是在 Java 中从 .NET 解密默认 RijndaelManaged 流的代码,假设它是使用原始密码作为密钥创建的:

Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
String password = "kallisti"; // only 8, 12, or 16 chars will work as a key
byte[] key = password.getBytes(Charset.forName("UTF-16LE"));
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding", "BC");
cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(key, "AES"),
    new IvParameterSpec(key));
return cipher; // then use CipherInputStream(InputStream, Cipher)

请记住:如果您控制 C# 端,请不要使用未派生的密码作为密钥!

解密由 加密的字节.NET的RijndaelManaged using Java

可以使用标准 AES 解密。Rijndel只是AES的一个超集,它在特定选项方面更为宽松。有关更多详细信息,请参阅 Java 中的 Rijndael 支持。

从链接问题中给出的答案:

byte[] sessionKey = null; //Where you get this from is beyond the scope of this post
byte[] iv = null ; //Ditto
byte[] plaintext = null; //Whatever you want to encrypt/decrypt
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
//You can use ENCRYPT_MODE or DECRYPT_MODE
cipher.calling init(Cipher.DECRYPT_MODE, new SecretKeySpec(sessionKey, "AES"), new IvParameterSpec(iv));
byte[] ciphertext = cipher.doFinal(plaintext);