C#对接java AES加解密遇到的问题及解决方案

遇到的问题

最近公司在和友商对接的时候遇到了一个问题,我方使用的是Java,友商用的是c#,友方对数据进行加密签名处理后,传到我方时,我方无法进行解密。

解决思路

我们首先双方分别用同样的key(123456789qwertyu)、对123456进行加密,对比双方的结果发现的到的加密后的密文不一样,友商是标准的aes加密,加密结果跟 AES在线加密网站,一致,如图
记一次C#对接java AES加解密遇到的问题及解决方案
而我方加密完后是“8lhAKaV8DbNrDJS+dYs8mg==”,苦苦思考未果,在
https://www.cnblogs.com/xbzhu/p/7064642.html 中知道了思路,原来是Java代码里面用到了KeyGenerator 和 SecureRandom,但是 .NET 里面没有这2个类。无法使用安全随机数生成KEY。
我们在接收JAVA发送的AES加密字符串后,在.NET没有对应的KeyGenerator 和 SecureRandom去生成AES 的 KEY值,导致无法直接解密。

如下图java代码
记一次C#对接java AES加解密遇到的问题及解决方案
就是上面红线中的几行代码导致的。

根据上面博客中的第二种方法,然后再优化下可以解决问题,博客中是这样描述的

下载IKVM ,解压缩后在VS的项目中引用bin目录下的IKVM.Runtime.dll、IKVM.OpenJDK.Core.dll、IKVM.OpenJDK.Security.dll

博客中的代码片段如下:

using java.security;
using javax.crypto;
using System.Security.Cryptography;
using System.Text;
using System;

public class Program
{
    public static void Main()
    {
        byte[] a = Convert.FromBase64String("W0fSdgixanavXMiDdPXa/Q==");
        string result = DeAES(a, "abcd1234");
        Console.WriteLine(result);
        Console.Read();
    }
    /// AES解密
    public static string DeAES(byte[] content, string key)
    {
        KeyGenerator kgen = KeyGenerator.getInstance("AES");
        SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
        secureRandom.setSeed(Encoding.ASCII.GetBytes(key));
        kgen.init(128, secureRandom);
        SecretKey secretKey = kgen.generateKey();
        byte[] enCodeFormat = secretKey.getEncoded();

        using (AesCryptoServiceProvider aesProvider = new AesCryptoServiceProvider())
        {
            aesProvider.Key = enCodeFormat;
            aesProvider.Mode = CipherMode.ECB;
            aesProvider.Padding = PaddingMode.PKCS7;
            using (ICryptoTransform cryptoTransform = aesProvider.CreateDecryptor())
            {
                byte[] inputBuffers = content;
                byte[] results = cryptoTransform.TransformFinalBlock(inputBuffers, 0, inputBuffers.Length);
                aesProvider.Clear();
                return Encoding.UTF8.GetString(results);
            }
        }
    }

}

我们需要引用五个dll,分别是IKVM.Runtime.dll、IKVM.OpenJDK.Core.dll、IKVM.OpenJDK.Security.dll、IKVM.OpenJDK.Charsets.dll、IKVM.OpenJDK.Util.dll
记一次C#对接java AES加解密遇到的问题及解决方案
到此,问题完美解决,希望可以帮助到大家。

相关文章:

  • 2022-12-23
  • 2021-12-05
  • 2021-12-06
  • 2021-12-16
  • 2022-12-23
  • 2021-05-19
  • 2022-12-23
  • 2021-07-11
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案