Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/343.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在C语言中解密AES加密字符串#_Java_C#_Encryption_Aes_Aescryptoserviceprovider - Fatal编程技术网

Java 在C语言中解密AES加密字符串#

Java 在C语言中解密AES加密字符串#,java,c#,encryption,aes,aescryptoserviceprovider,Java,C#,Encryption,Aes,Aescryptoserviceprovider,我试图用C#从Java解密AES加密字符串。当我解密时,它返回乱码,并且与原始纯文本不匹配,而原始纯文本是通过Java代码加密的。请告诉我这里出了什么问题 附上用于加密的Java代码和用于解密的C#代码。如果你需要更多的细节,请告诉我 我也尝试了AesCryptoServiceProvider,但它也不起作用。您可以在C#中的注释代码中看到尝试的代码 请注意,我只能更改我的C#代码以匹配Java代码,不能对Java端进行任何编辑 用于加密的Java代码: C#解密代码: 这只是一个简单的答案。我

我试图用C#从Java解密AES加密字符串。当我解密时,它返回乱码,并且与原始纯文本不匹配,而原始纯文本是通过Java代码加密的。请告诉我这里出了什么问题

附上用于加密的Java代码和用于解密的C#代码。如果你需要更多的细节,请告诉我

我也尝试了AesCryptoServiceProvider,但它也不起作用。您可以在C#中的注释代码中看到尝试的代码

请注意,我只能更改我的C#代码以匹配Java代码,不能对Java端进行任何编辑

用于加密的Java代码: C#解密代码:
这只是一个简单的答案。我还没有做过大量的研究,但是你检查过endian ness是否匹配吗?看起来C#(.NET)是小端,但JVM是大端。但是,我不确定它是否将其交换为网络传输(那么它将只匹配硬件)。只是个主意。如果我发现任何其他问题,我会更新我的答案。

这只是一个快速的答案。我还没有做过大量的研究,但是你检查过endian ness是否匹配吗?看起来C#(.NET)是小端,但JVM是大端。但是,我不确定它是否将其交换为网络传输(那么它将只匹配硬件)。只是个主意。如果我发现任何其他问题,我将更新我的答案。

您不设置IV()。这通常应该与加密文本一起附加(这不是秘密!),并且应该在
aesAlg.IV
属性()中设置。但我不知道在Java密码中从何处读取它。这可能是一个编码问题,因为大多数值都编码到base64或从base64中读取。例如,在Java中,
字符串
加密后被编码为base64,但在C中#解密后,
字符串
不会被解码。@Jens-因为在共享的Java代码中,我没有看到任何IV集,所以我也没有在C中设置一个IV集。我不知道这个库在Java中的默认IV。我猜它将在初始化步骤中随机生成,但这实际上只是一种预感,因为我对Java实现一无所知。但这可以解释问题;-)@ArtjomB.-嗨-我的加密密钥是24字节长。正如我提到的,Java进程是一个已经存在的进程,并且被许多其他系统使用。它已经使用AES,我无法对其进行任何编辑。我尝试了ECB以外的其他模式,它们都给出了错误“要解密的数据长度无效”。如前所述,在使用ECB解密后,它返回一些胡言乱语,并且与原始纯文本不匹配。这通常应该与加密文本一起附加(这不是秘密!),并且应该在
aesAlg.IV
属性()中设置。但我不知道在Java密码中从何处读取它。这可能是一个编码问题,因为大多数值都编码到base64或从base64中读取。例如,在Java中,
字符串
加密后被编码为base64,但在C中#解密后,
字符串
不会被解码。@Jens-因为在共享的Java代码中,我没有看到任何IV集,所以我也没有在C中设置一个IV集。我不知道这个库在Java中的默认IV。我猜它将在初始化步骤中随机生成,但这实际上只是一种预感,因为我对Java实现一无所知。但这可以解释问题;-)@ArtjomB.-嗨-我的加密密钥是24字节长。正如我提到的,Java进程是一个已经存在的进程,并且被许多其他系统使用。它已经使用AES,我无法对其进行任何编辑。我尝试了ECB以外的其他模式,它们都给出了错误“要解密的数据长度无效”。如前所述,在ECB解密后,它返回一些胡言乱语,与原始纯文本不匹配。让我研究一下,看看。谢谢你的快速回复。我看到你说Java端已经在使用了。仅仅是正在进行解密的java代码还是C++?除了在C#中重写它之外,另一个选择是使用已经存在的代码并添加包装器。ps:我相信aesAlg.KeySize应该是:your Key.Length*8=24*8=192而不是256Hi-Jon-我之前也尝试过192,但它仍然会返回一些垃圾作为解密值。我们有一个Java Web服务,它以加密格式返回数据,我正试图从我的.Net应用程序中解密数据。让我研究一下,看看。谢谢你的快速回复。我看到你说Java端已经在使用了。仅仅是正在进行解密的java代码还是C++?除了在C#中重写它之外,另一个选择是使用已经存在的代码并添加包装器。ps:我相信aesAlg.KeySize应该是:your Key.Length*8=24*8=192而不是256Hi-Jon-我之前也尝试过192,但它仍然会返回一些垃圾作为解密值。我们有一个JavaWebService,它以加密格式返回数据,我正试图从我的.Net应用程序中解密数据。
/** encrypt cipher */
private static final Cipher ENCRYPT_CIPHER = generateCipher(Cipher.ENCRYPT_MODE);

private static String ENCRYPT_KEY = "key";

/**
 * @param val
 * @return encrypted value
 * @throws Exception
 */
public String encrypt(final String val) throws Exception {
    return new String(Base64.encodeBase64(ENCRYPT_CIPHER.doFinal(val.getBytes()), true)).toString();
}

/**
 * @param encrypt
 * @return cipher
 */
protected static Cipher generateCipher(final int encrypt) {
    try {
        final Cipher cipher = Cipher.getInstance("AES");
        cipher.init(encrypt, SecretKeyFactory.getInstance("AES").generateSecret(new IBMAESKeySpec(Base64.decodeBase64(ENCRYPT_KEY.getBytes()))));
        return cipher;
    } catch (final Exception e) {
        return null;
    }
}
private static String ENCRYPT_KEY = "key";
public String decodeString (String encodedStr)
{

/*using (var aesCryptoProvider = new AesCryptoServiceProvider())
    {
    aesCryptoProvider.BlockSize = 128;
    aesCryptoProvider.KeySize = 256;
    aesCryptoProvider.Key = Convert.FromBase64String(ENCRYPT_KEY.ToString());
    aesCryptoProvider.Padding = PaddingMode.Zeros;
    aesCryptoProvider.Mode = CipherMode.ECB;

    using (var decryptor = aesCryptoProvider.CreateDecryptor())
    using (var memoryStream = new MemoryStream(Convert.FromBase64String(encodedStr)))
    using (var cryptoStream = new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read))
    using (var streamReader = new StreamReader(cryptoStream, Encoding.UTF8))
    {
        decodedStr = streamReader.ReadToEnd();
    }
    } 
 */
    using (AesManaged aesAlg = new AesManaged())
        {
        aesAlg.Key = Convert.FromBase64String(ENCRYPT_KEY.ToString()); ;
        aesAlg.BlockSize = 128;
        aesAlg.KeySize = 256;
        aesAlg.Mode = CipherMode.ECB;
        aesAlg.Padding = PaddingMode.Zeros;
        // Create a decrytor to perform the stream transform.
        ICryptoTransform decryptor = aesAlg.CreateDecryptor();

        // Create the streams used for decryption.
        using (MemoryStream msDecrypt = new MemoryStream(Convert.FromBase64String(encodedStr)))
        {
            using (CryptoStream csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
            {
            using (StreamReader srDecrypt = new StreamReader(csDecrypt))
            {

                // Read the decrypted bytes from the decrypting stream
                // and place them in a string.
                decodedStr = srDecrypt.ReadToEnd();
            }
            }
        }

     }
}