java - C# 和 Java 中的 AES 加密文件

标签 java c# servlets encryption aes

我用 C# 方法加密了文件:

public byte[] Crypt(byte[] filearray, string sKey)
        {
                AesManaged DES = new AesManaged();
                DES.Key = Encoding.UTF8.GetBytes(sKey);
                DES.Mode = CipherMode.ECB;
                DES.Padding = PaddingMode.PKCS7;
                ICryptoTransform crypt = DES.CreateEncryptor();
                byte[] cipher = crypt.TransformFinalBlock(niz, 0, filearray.Length);
                String encryptedText = Convert.ToBase64String(cipher);
                return cipher.ToArray();
            }

现在我尝试用Java解密文件:

private static byte[] transform(string base64Key, final byte[] fileBytes) throws InvalidKeyException, InvalidAlgorithmParameterException, NoSuchProviderException
   {
       final byte[] keyBytes = base64Key.getBytes(StandardCharsets.UTF_8);
       final byte[] ivBytes = base64Iv.getBytes(StandardCharsets.UTF_8);
       final SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "AES");
       final IvParameterSpec ivSpec = new IvParameterSpec(ivBytes);
       byte[] transformedBytes = null;
       try
       {
           Security.addProvider(new BouncyCastleProvider());
           final Cipher cipher = Cipher.getInstance("AES/ECB/PKCS7Padding");;
           cipher.init(Cipher.DECRYPT_MODE, keySpec);
           transformedBytes = cipher.doFinal(fileBytes);
       }        
       catch (NoSuchAlgorithmException | NoSuchPaddingException | IllegalBlockSizeException | 
               BadPaddingException e) 
       {
           e.printStackTrace();
       }
       return transformedBytes;
   }

当我尝试执行此函数时,出现异常

javax.crypto.BadPaddingException: pad block corrupted at org.bouncycastle.jcajce.provider.symmetric.util.BaseBlockCipher$BufferedGenericBlockCipher.doFinal(Unknown Source) at org.bouncycastle.jcajce.provider.symmetric.util.BaseBlockCipher.engineDoFinal(Unknown Source) at javax.crypto.Cipher.doFinal(Cipher.java:2165)

最佳答案

尝试使用不同的填充,例如:

Cipher.getInstance("AES/ECB/NoPadding");

Cipher.getInstance("AES/ECB/PKCS5Padding");

而不是

Cipher.getInstance("AES/ECB/PKCS7Padding");

关于java - C# 和 Java 中的 AES 加密文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59236368/

相关文章:

java - 在 servlet 过滤器中同步代码

java - 使用 Lucene SearchAfter 示例

C# 图像空白

Java session ID : How to get the Name of the GET SessionID Parameter?

c# - 如何以编程方式填充 DataGridView

c# - 使用扩展方法替换字符串

jsp - 创建一个Excel文件供用户使用Apache POI下载

java - 如何从另一个 Runnable 类更新 java GUI? java

JavaFX MediaPlayer 无法播放带有大 png 封面的 mp3

Java 8 方法引用 : provide a Supplier capable of supplying a parameterized result