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

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

遇到的问题

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

解决思路

我们首先双方分别用同样的key(123456789qwertyu)、对123456进行加密,对比双方的结果发现的到的加密后的密文不一样,友商是标准的aes加密,加密结果跟 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代码
在这里插入图片描述
就是上面红线中的几行代码导致的。

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

下载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
在这里插入图片描述
到此,问题完美解决,希望可以帮助到大家。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值