.NET对JAVA进行AES加密(SHA1PRNG)及解密方法

第一步:生成对应JAVA AES加密方法的KEY值

private static byte[] encryptJavaAes(string aesKey)
        {
            byte[] keyArray = null;
            using (var sha1 = new SHA1CryptoServiceProvider())
            {
                byte[] hash = sha1.ComputeHash(Encoding.UTF8.GetBytes(aesKey));
                var rd = sha1.ComputeHash(hash);
                keyArray = rd.Take(16).ToArray();
                /* 将字节流转换成字符串输出
                Base64Encoder coder = new Base64Encoder();
                coder.GetEncoded(keyArray);
                 * */
            }
            return keyArray;
        }

第二步:加密对应的字符串

/// <summary>
        /// .NET对JAVA进行AES加密
        /// </summary>
        /// <param name="encryptString">需要加密的字符串</param>
        /// <returns></returns>
        private static string AESEncode(string encryptString)
        {
            if (string.IsNullOrEmpty(encryptString)) return null;
            Byte[] toEncryptArray = Encoding.UTF8.GetBytes(encryptString);
            RijndaelManaged rm = new RijndaelManaged
            {
                Key = encryptJavaAes("DCS"),//Convert.FromBase64String(encryptKey),
                Mode = CipherMode.ECB,
                Padding = PaddingMode.PKCS7
            };
            ICryptoTransform cTransform = rm.CreateEncryptor();
            Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
            return Convert.ToBase64String(resultArray, 0, resultArray.Length);
        }

第三步:解密加密的字符串

/// <summary>
        /// 解密加密的字符串
        /// </summary>
        /// <param name="toDecrypt">需要解密的字符串</param>
        /// <returns></returns>
        private static string decrypt(string toDecrypt)
        {
            string aeskey = System.Configuration.ConfigurationManager.AppSettings["aeskey"];
            byte[] keyArray = encryptJavaAes(“DCS”);//Convert.FromBase64String(key); 
            byte[] toEncryptArray = Convert.FromBase64String(toDecrypt);
            RijndaelManaged rDel = new RijndaelManaged();
            rDel.Key = keyArray;
            rDel.Mode = CipherMode.ECB;        //必须设置为ECB
            rDel.Padding = PaddingMode.PKCS7;  //必须设置为PKCS7
            ICryptoTransform cTransform = rDel.CreateDecryptor();
            byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
            return UTF8Encoding.UTF8.GetString(resultArray);
        }

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值