RSA 非对称加密与解密

本文介绍了一个使用RSA算法进行字符串加密和解密的实现方法。该方法能够处理不同密钥长度的数据块,并通过MemoryStream进行数据操作。适用于需要对信息进行安全传输的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        private static string Encrypt(string msg, string publickey)
        {
            ASCIIEncoding enc = new ASCIIEncoding();
            byte[] bytes = enc.GetBytes(msg);
            int blockSize = 0;
            RSACryptoServiceProvider crypt = new RSACryptoServiceProvider();
            crypt.FromXmlString(publickey);
            if (crypt.KeySize == 1024)
                blockSize = 16;
            else
                blockSize = 8;

            MemoryStream ms = new MemoryStream();

            byte[] rawblock, encryblock;
            for (int i = 0; i < bytes.Length; i += blockSize)
            {
                if ((bytes.Length - i) > blockSize)
                    rawblock = new byte[blockSize];
                else
                    rawblock = new byte[bytes.Length - i];
                Buffer.BlockCopy(bytes, i, rawblock, 0, rawblock.Length);
                encryblock = crypt.Encrypt(rawblock, false);
                ms.Write(encryblock, 0, encryblock.Length);
            }

            ms.Position = 0;
            byte[] decode = new byte[ms.Length];
            ms.Read(decode, 0, (int)ms.Length);

            string decodeinfo = Convert.ToBase64String(decode);
            ms.Close();
            return decodeinfo;

        }
        private static string Decrypt(string msg, string privatekey)
        {
            RSACryptoServiceProvider crypt = new RSACryptoServiceProvider();
            crypt.FromXmlString(privatekey);

            ASCIIEncoding enc = new ASCIIEncoding();
            byte[] bytes = Convert.FromBase64String(msg);

            MemoryStream ms = new MemoryStream();
            int keySize = crypt.KeySize / 8;
            byte[] rawblock, decryptblock;
            for (int i = 0; i < bytes.Length; i += keySize)
            {
                if ((bytes.Length - i) > keySize)
                {
                    rawblock = new byte[keySize];
                }
                else
                { rawblock = new byte[bytes.Length - i]; }

                Buffer.BlockCopy(bytes, i, rawblock, 0, rawblock.Length);
                decryptblock = crypt.Decrypt(rawblock, false);
                ms.Write(decryptblock, 0, decryptblock.Length);
            }
            ms.Position = 0;
            byte[] decode = new byte[ms.Length];
            ms.Read(decode, 0, (int)ms.Length);

            string text = enc.GetString(decode);
            ms.Close();
            return text;

        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值