RSA C#

RSA加密算法是一种非对称加密算法。在公钥加密标准和电子商业中RSA被广泛使用。RSA是1977年由罗纳德•李维斯特(Ron Rivest)、阿迪•萨莫尔(Adi Shamir)和伦纳德•阿德曼(Leonard Adleman)一起提出的。当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏开头字母拼在一起组成的。.Net的推出,我们能够利用.Net Framework中的类提供的加密服务来保证数据安全。目前应用较为广泛的加密方法是使用RSA算法进行加密。在.Net Framework中与RSA加密算法相关的类主要有两个:RSA 类和RSACryptoServiceProvider 类。按照MSDN的说法RSA 类是“表示 RSA 算法的所有实现均从中继承的基类”,而RSACryptoServiceProvider 类是“使用加密服务提供程序 (CSP) 提供的 RSA 算法的实现执行不对称加密和解密”。另外,“表示 RSA 算法的标准参数”的RSAParameters 结构也是很重要的,它保存了RSA算法的参数。
这里具体讲述一下在C#中如何使用框架提供的RSA算法来对我们的信息加密、签名、验证签名、解密的这个几个步骤的实现

        using System.Security.Cryptography;

        using System.Management;

        using Microsoft.Win32;

        /// <summary>

        /// 生成公私钥

        /// </summary>

        /// <param name="PrivateKeyPath"></param>

        /// <param name="PublicKeyPath"></param>

        public void RSAKey(string PrivateKeyPath, string PublicKeyPath)

        {

            try

            {

                RSACryptoServiceProvider provider = new RSACryptoServiceProvider();

                this.CreatePrivateKeyXML(PrivateKeyPath, provider.ToXmlString(true));

                this.CreatePublicKeyXML(PublicKeyPath, provider.ToXmlString(false));

            }

            catch (Exception exception)

            {

                throw exception;

            }

        }

        /// <summary>

        /// 对原始数据进行MD5加密

        /// </summary>

        /// <param name="m_strSource">待加密数据</param>

        /// <returns>返回机密后的数据</returns>

        public string GetHash(string m_strSource)

        {

            HashAlgorithm algorithm = HashAlgorithm.Create("MD5");

            byte[] bytes = Encoding.GetEncoding("GB2312").GetBytes(m_strSource);

            byte[]>

            return Convert.ToBase64String(inArray);

        }

        /// <summary>

        /// RSA加密

        /// </summary>

        /// <param name="xmlPublicKey">公钥</param>

        /// <param name="m_strEncryptString">MD5加密后的数据</param>

        /// <returns>RSA公钥加密后的数据</returns>

        public string RSAEncrypt(string xmlPublicKey, string m_strEncryptString)

        {

            string str2;

            try

            {

                RSACryptoServiceProvider provider = new RSACryptoServiceProvider();

                provider.FromXmlString(xmlPublicKey);

                byte[] bytes = new UnicodeEncoding().GetBytes(m_strEncryptString);

                str2 = Convert.ToBase64String(provider.Encrypt(bytes, false));

            }

            catch (Exception exception)

            {

                throw exception;

            }

            return str2;

        }

        /// <summary>

        /// RSA解密

        /// </summary>

        /// <param name="xmlPrivateKey">私钥</param>

        /// <param name="m_strDecryptString">待解密的数据</param>

        /// <returns>解密后的结果</returns>

        public string RSADecrypt(string xmlPrivateKey, string m_strDecryptString)

        {

            string str2;

            try

            {

                RSACryptoServiceProvider provider = new RSACryptoServiceProvider();

                provider.FromXmlString(xmlPrivateKey);

                byte[] rgb = Convert.FromBase64String(m_strDecryptString);

                byte[] buffer2 = provider.Decrypt(rgb, false);

                str2 = new UnicodeEncoding().GetString(buffer2);

            }

            catch (Exception exception)

            {

                throw exception;

            }

            return str2;

        }

        /// <summary>

        /// 对MD5加密后的密文进行签名

        /// </summary>

        /// <param name="p_strKeyPrivate">私钥</param>

        /// <param name="m_strHashbyteSignature">MD5加密后的密文</param>

        /// <returns></returns>

        public string SignatureFormatter(string p_strKeyPrivate, string m_strHashbyteSignature)

        {

            byte[] rgbHash = Convert.FromBase64String(m_strHashbyteSignature);

            RSACryptoServiceProvider key = new RSACryptoServiceProvider();

            key.FromXmlString(p_strKeyPrivate);

            RSAPKCS1SignatureFormatter formatter = new RSAPKCS1SignatureFormatter(key);

            formatter.SetHashAlgorithm("MD5");

            byte[]>

            return Convert.ToBase64String(inArray);

        }

        /// <summary>

        /// 签名验证

        /// </summary>

        /// <param name="p_strKeyPublic">公钥</param>

        /// <param name="p_strHashbyteDeformatter">待验证的用户名</param>

        /// <param name="p_strDeformatterData">注册码</param>

        /// <returns></returns>

        public bool SignatureDeformatter(string p_strKeyPublic, string p_strHashbyteDeformatter, string p_strDeformatterData)

        {

            try

            {

                byte[] rgbHash = Convert.FromBase64String(p_strHashbyteDeformatter);

                RSACryptoServiceProvider key = new RSACryptoServiceProvider();

                key.FromXmlString(p_strKeyPublic);

                RSAPKCS1SignatureDeformatter deformatter = new RSAPKCS1SignatureDeformatter(key);

                deformatter.SetHashAlgorithm("MD5");

                byte[] rgbSignature = Convert.FromBase64String(p_strDeformatterData);

                if (deformatter.VerifySignature(rgbHash, rgbSignature))

                {

                    return true;

                }

                return false;

            }

            catch

            {

                return false;

            }

        }

        /// <summary>

        /// 获取硬盘ID

        /// </summary>

        /// <returns>硬盘ID</returns>

        public string GetHardID()

        {

            string HDInfo = "";

            ManagementClass cimobject1 = new ManagementClass("Win32_DiskDrive");

            ManagementObjectCollection moc1 = cimobject1.GetInstances();

            foreach (ManagementObject mo in moc1)

            {

                HDInfo = (string)mo.Properties["Model"].Value;

            }

            return HDInfo;

        }

        /// <summary>

        /// 读注册表中指定键的值

        /// </summary>

        /// <param name="key">键名</param>

        /// <returns>返回键值</returns>

        private string ReadReg(string key)

        {

            string temp = "";

            try

            {

                RegistryKey myKey = Registry.LocalMachine;

                RegistryKey subKey = myKey.OpenSubKey(@"SOFTWARE/JX/Register");

 

                temp = subKey.GetValue(key).ToString();

                subKey.Close();

                myKey.Close();

                return temp;

            }

            catch (Exception)

            {

                throw;//可能没有此注册项;

            }

 

        } 

        /// <summary>

        /// 创建注册表中指定的键和值

        /// </summary>

        /// <param name="key">键名</param>

        /// <param name="value">键值</param>

        private void WriteReg(string key, string value)

        {

            try

            {

                RegistryKey rootKey = Registry.LocalMachine.CreateSubKey(@"SOFTWARE/JX/Register");

                rootKey.SetValue(key, value);

                rootKey.Close();

            }

            catch (Exception)

            {

                throw;

            }

        }

        /// <summary>

        /// 创建公钥文件

        /// </summary>

        /// <param name="path"></param>

        /// <param name="publickey"></param>

        public void CreatePublicKeyXML(string path, string publickey)

        {

            try

            {

                FileStream publickeyxml = new FileStream(path, FileMode.Create);

                StreamWriter sw = new StreamWriter(publickeyxml);

                sw.WriteLine(publickey);

                sw.Close();

                publickeyxml.Close();

            }

            catch

            {

                throw;

            }

        }

        /// <summary>

        /// 创建私钥文件

        /// </summary>

        /// <param name="path"></param>

        /// <param name="privatekey"></param>

        public void CreatePrivateKeyXML(string path, string privatekey)

        {

            try

            {

                FileStream privatekeyxml = new FileStream(path, FileMode.Create);

                StreamWriter sw = new StreamWriter(privatekeyxml);

                sw.WriteLine(privatekey);

                sw.Close();

                privatekeyxml.Close();

            }

            catch

            {

                throw;

            }

        }

        /// <summary>

        /// 读取公钥

        /// </summary>

        /// <param name="path"></param>

        /// <returns></returns>

        public string ReadPublicKey(string path)

        {

            StreamReader reader = new StreamReader(path);

            string publickey = reader.ReadToEnd();

            reader.Close();

            return publickey;

        }

        /// <summary>

        /// 读取私钥

        /// </summary>

        /// <param name="path"></param>

        /// <returns></returns>

        public string ReadPrivateKey(string path)

        {

            StreamReader reader = new StreamReader(path);

            string privatekey = reader.ReadToEnd();

            reader.Close();

            return privatekey;

        }

        /// <summary>

        /// 初始化注册表,程序运行时调用,在调用之前更新公钥xml

        /// </summary>

        /// <param name="path">公钥路径</param>

        public void InitialReg(string path)

        {

            Registry.LocalMachine.CreateSubKey(@"SOFTWARE/JX/Register");

            Random ra = new Random();

            string publickey = this.ReadPublicKey(path);

            if (Registry.LocalMachine.OpenSubKey(@"SOFTWARE/JX/Register").ValueCount <= 0)

            {

                this.WriteReg("RegisterRandom", ra.Next(1,100000).ToString());

                this.WriteReg("RegisterPublicKey", publickey);

            }

            else

            {

                this.WriteReg("RegisterPublicKey", publickey);

            }

        } 

转载自http://blog.youkuaiyun.com/llwinnner/article/details/4011936

### 回答1: RSA是一种非对称加密算法,通过利用大质数的特性,可以实现可靠的加密和解密过程。 RSA加密过程中,首先需要生成一对密钥,即公钥和私钥。公钥用于加密数据,私钥用于解密数据。 具体加密过程如下: 1. 选取两个同的质数p和q,并计算它们的乘积n。 2. 计算n的欧拉函数φ(n),即φ(n) = (p-1)(q-1)。 3. 选取一个int型的整数e,使得1<e<φ(n),且e与φ(n)互质。 4. 计算e关于φ(n)的乘法逆元d,即d·e=1(mod φ(n))。 5. 公钥为(n, e),私钥为(n, d)。 6. 将明文数据转化为对应的十进制数m。 7. 加密过程为:c ≡ m^e(mod n)。 8. 得到密文c。 RSA解密过程如下: 1. 将密文c代入解密公式:m ≡ c^d(modn),得到明文m。 相比于其他加密算法,RSA具有加密效率低的特点,但是由于非对称加密的特性,它可以更好地保证数据的安全性。在JS中,通过使用各种开源的加密库,可以方便地实现RSA加密和解密的功能。 总结来说,JS加密RSA C是指通过使用JavaScript实现RSA加密算法,实现数据加密和解密的过程,保证数据的机密性和安全性。 ### 回答2: RSA是一种非对称加密算法,可以用于保护数据的安全性。在使用JavaScript进行RSA加密时,需要使用RSA加密算法的相关库或插件以实现相关功能。 在JavaScript中,我们可以使用如crypto-js或jsencrypt等库来进行RSA加密。这些库提供了一系列方法来生成RSA密钥对、加密和解密数据。 首先,我们需要生成RSA密钥对。可以使用库提供的方法来生成公钥和私钥。公钥用于加密数据,私钥用于解密数据。 使用RSA加密数据的过程如下:首先,将需要加密的数据通过公钥进行加密操作。加密后的数据可以通过网络传输或在本地存储。在接收方获取到加密数据后,可以使用私钥对其进行解密操作,以获取原始数据。 在使用RSA加密数据时,需要保证私钥的安全性,以免私钥被他人获取而导致数据泄露。因此,使用RSA加密时需要合理管理密钥,以保障数据的安全性。 总而言之,使用JavaScript进行RSA加密需要使用相关的库或插件,生成RSA密钥对并通过公钥加密数据,再通过私钥解密数据。加密数据的安全性取决于私钥的保护程度。 ### 回答3: RSA加密是一种非对称加密算法,用于保护数据的安全性和隐私性。在JavaScript中,我们可以使用一些库来实现RSA加密算法。 首先,我们需要准备一对RSA密钥,包括公钥和私钥。通常情况下,公钥用于加密数据,而私钥用于解密数据。可以通过一些在线工具或者自己生成密钥对。 接下来,我们需要引入一个JSRSA库,如"jsencrypt"来实现RSA加密。可以通过在HTML文档中引入该库的JavaScript文件或者使用npm进行安装。 接下来,我们可以在JavaScript代码中通过以下步骤来实现RSA加密: 1. 创建一个RSA实例,并传入公钥。 2. 调用实例的encrypt方法,传入要加密的数据作为参数。 3. 得到加密后的数据,可以通过调用实例的getEncryptedString方法来获取加密后的字符串。 下面是一个简单的示例代码: ```javascript // 引入jsencrypt库 const JSEncrypt = require('jsencrypt'); // 创建RSA实例 const rsa = new JSEncrypt(); // 设置公钥 rsa.setPublicKey(publicKey); // 要加密的数据 const data = 'Hello, RSA!'; // 加密数据 const encryptedData = rsa.encrypt(data); // 输出加密后的数据 console.log(encryptedData); ``` 以上示例中,我们通过传入公钥给RSA实例,并使用encrypt方法对数据进行加密,最后输出加密后的数据。 需要注意的是,RSA加密算法是一种非常安全和复杂的算法,仅仅使用以上代码可能还够保证数据的安全性。在真实的场景中,还需要考虑密钥的生成和管理,以及数据的完整性和验证等方面的问题。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值