【转】C#中RSA加密解密和签名与验证的实现

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[] inArray = algorithm.ComputeHash(bytes);

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[] inArray = formatter.CreateSignature(rgbHash);

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>

privatestring 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>

privatevoid 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 =
newFileStream(path,
FileMode.Create);

StreamWriter sw =
newStreamWriter(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 =
newFileStream(path,
FileMode.Create);

StreamWriter sw =
newStreamWriter(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 =
newStreamReader(path);

string publickey = reader.ReadToEnd();

reader.Close();

return publickey;

}

///
<summary>

///
读取私钥

///
</summary>

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

///
<returns></returns>

public
string ReadPrivateKey(string path)

{

StreamReader reader =
newStreamReader(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 =
newRandom();

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);

}

}

如果是要对发送的消息进行加密和解密,加密时用公钥,解密时用私钥,即使密文被窃取也无法破解。

如果是要对软件进行注册,生成注册码,则服务端将用户的硬盘号用私钥加密,客户端用公钥解密,解密后将客户端的硬盘号进行MD5加密,将得到的结果和解密后的结果进行比较,如果相同,说明是注册用户,否则为非注册用户。

【转】C#中RSA加密解密和签名与验证的实现的更多相关文章

  1. C#中RSA加密解密和签名与验证的实现

    RSA加密算法是一种非对称加密算法.在公钥加密标准和电子商业中RSA被广泛使用.RSA是1977年由罗纳德•李维斯特(Ron Rivest).阿迪•萨莫尔(Adi Shamir)和伦纳德•阿德曼(Le ...

  2. OpenSSL 中 RSA 加密解密实现源代码分析

    1.RSA 公钥和私钥的组成.以及加密和解密的公式: 2.模指数运算: 先做指数运算,再做模运算.如 5^3 mod 7 = 125 mod 7 = 6 3.RSA加密算法流程: 选择一对不同的.而且 ...

  3. Java使用RSA加密解密及签名校验

    该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar注意:RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行 ...

  4. .net中RSA加密解密

    1.产生密钥: private static void CreateKey() { using (RSACryptoServiceProvider rsa = new RSACryptoService ...

  5. php中rsa加密解密验证

    RSA非对称加密,对敏感的数据传输进行数据加密.验证等.测试环境:wamp.aliyun虚拟主机(lamp)一.加密解密的第一步是生成公钥.私钥对,私钥加密的内容能通过公钥解密(反过来亦可以).下载生 ...

  6. Python下RSA加密/解密, 签名/验证

    原文是py2环境,而我的环境是py3,所以对原代码做了修改:decode(), encode() import rsa # 生成密钥 (pubkey, privkey) = rsa.newkeys(1 ...

  7. python下RSA 加密/解密,签名/验证

    基于win7 + python3.4 原文是py2环境,而我的环境是py3,所以对原代码做了修改:decode(), encode() import rsa # 生成密钥 (pubkey, privk ...

  8. C# Java间进行RSA加密解密交互

    原文:C# Java间进行RSA加密解密交互 这里,讲一下RSA算法加解密在C#和Java之间交互的问题,这两天纠结了很久,也看了很多其他人写的文章,颇受裨益,但没能解决我的实际问题,终于,还是被我捣 ...

  9. iOS使用Security.framework进行RSA 加密解密签名和验证签名

    iOS 上 Security.framework为我们提供了安全方面相关的api: Security框架提供的RSA在iOS上使用的一些小结 支持的RSA keySize 大小有:512,768,10 ...

随机推荐

  1. 1806最大数 string和sort函数用法

    1.C++自带sort函数用法 sort函数有三个参数: (1)第一个是要排序的数组的起始地址 (2)第二个是结束的地址(最后一位要排序的地址) (3)第三个参数是排序的方法,可以是从大到小也可是从小 ...

  2. NYOJ 16 矩形嵌套【DP】

    解题思路:呃,是看的紫书上面的做法,一个矩形和另一个矩形之间的关系就只有两种,(因为它自己是不能嵌套自己的),可嵌套,不可嵌套,是一个二元关系,如果可嵌套的话,则记为1,如果不可嵌套的话则记为0,就可 ...

  3. swift语言点评十六-Initialization && Deinitialization

    initial value:必须初始化.不影响观察者 Classes and structures must set all of their stored properties to an appr ...

  4. Git常见问题 资料汇总

    来源https://blog.csdn.net/albb_/article/details/80420468

  5. springMVC小项目实例

    一.什么是 Spring MVC Spring MVC 属于 SpringFrameWork 的后续产品,已经融合在 Spring Web Flow 里面,是一个强大灵活的 Web 框架.Spring ...

  6. java中,length,length(),size()区别

    length——数组的属性: length()——String的方法: size()——集合的方法:

  7. [细节版]Let'sEncrypt 免费通配符/泛域名SSL证书添加使用教程

    参考网址:https://lnmp.org/faq/letsencrypt-wildcard-ssl.html 使用的dns服务商:阿里云 , 更多服务商地址可见参考网址. 遇见的问题一. [Sat ...

  8. BZOJ 2246 [SDOI2011]迷宫探险 (记忆化搜索)

    题目大意:太长了,略 bzoj luogu 并没有想到三进制状压 题解: 3进制状压陷阱的状态,0表示这种陷阱的状态未知,1已知危险,2已知不危险 然后预处理出在当前状态下,每种陷阱有害的概率,设为$ ...

  9. 题解 P3128 【[USACO15DEC]最大流Max Flow】

    此类型题目有两种比较常见的做法:树链剖分和树上差分. 本题有多组修改一组询问,因此树上差分会比树链剖分优秀很多. 这里两种方法都进行介绍. 树链剖分和树上差分的本质都是将一颗树转换为一个区间,然后进行 ...

  10. IDEA中编写脚本并运行shell脚本

    IDEA中编写脚本并运行shell脚本     来自 <https://blog.csdn.net/u012443641/article/details/81295999>