【转】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加密解密和签名与验证的实现的更多相关文章
- C#中RSA加密解密和签名与验证的实现
RSA加密算法是一种非对称加密算法.在公钥加密标准和电子商业中RSA被广泛使用.RSA是1977年由罗纳德•李维斯特(Ron Rivest).阿迪•萨莫尔(Adi Shamir)和伦纳德•阿德曼(Le ...
- OpenSSL 中 RSA 加密解密实现源代码分析
1.RSA 公钥和私钥的组成.以及加密和解密的公式: 2.模指数运算: 先做指数运算,再做模运算.如 5^3 mod 7 = 125 mod 7 = 6 3.RSA加密算法流程: 选择一对不同的.而且 ...
- Java使用RSA加密解密及签名校验
该工具类中用到了BASE64,需要借助第三方类库:javabase64-1.3.1.jar注意:RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行 ...
- .net中RSA加密解密
1.产生密钥: private static void CreateKey() { using (RSACryptoServiceProvider rsa = new RSACryptoService ...
- php中rsa加密解密验证
RSA非对称加密,对敏感的数据传输进行数据加密.验证等.测试环境:wamp.aliyun虚拟主机(lamp)一.加密解密的第一步是生成公钥.私钥对,私钥加密的内容能通过公钥解密(反过来亦可以).下载生 ...
- Python下RSA加密/解密, 签名/验证
原文是py2环境,而我的环境是py3,所以对原代码做了修改:decode(), encode() import rsa # 生成密钥 (pubkey, privkey) = rsa.newkeys(1 ...
- python下RSA 加密/解密,签名/验证
基于win7 + python3.4 原文是py2环境,而我的环境是py3,所以对原代码做了修改:decode(), encode() import rsa # 生成密钥 (pubkey, privk ...
- C# Java间进行RSA加密解密交互
原文:C# Java间进行RSA加密解密交互 这里,讲一下RSA算法加解密在C#和Java之间交互的问题,这两天纠结了很久,也看了很多其他人写的文章,颇受裨益,但没能解决我的实际问题,终于,还是被我捣 ...
- iOS使用Security.framework进行RSA 加密解密签名和验证签名
iOS 上 Security.framework为我们提供了安全方面相关的api: Security框架提供的RSA在iOS上使用的一些小结 支持的RSA keySize 大小有:512,768,10 ...
随机推荐
- windows共享如何重新登录,或用另外的用户登录
使用net use * /del 可以结束已有的所有连接,或net use \\192.168.1.10 /del可以结束指定连接.比如想重新登录共享的话,就用这个命令结束原来的连接,就可以重新登录 ...
- QT笔记 -- (6) opengl
参考 http://blog.csdn.net/myths_0/article/details/24431597 用glut绘制一个茶壶 一句话,继承QGLWidget,实现下面三个函数,用子类定义窗 ...
- php 添加redis扩展
我主要是按照http://blog.163.com/fan_xy_qingyuan/blog/static/1889877482014111111283265/ 这篇博客来的,但是这篇博客里只有php ...
- HDU 1394 Minimum Inversion Number【 树状数组 】
题意:给出n个数,每次可以把第一个数挪到最后一个位置去,问这n种排列里面的最小逆序对数 先把最开始的逆序对数求出来 然后对于一个数a[i],比它小的数有a[i] - 1个,比它大的数有n - a[i] ...
- Dapper基础知识四之 利用Dapper获取不同类型的主键值
在下刚毕业工作,之前实习有用到Dapper?这几天新项目想用上Dapper,在下比较菜鸟,这块只是个人对Dapper的一种总结. 一下是Dapper源码几种主键,当主键不包含"ID" ...
- LAMP 建立 Wordpress 站点 Linux Apache MariaDB PHP
使用LAMP建立Wordpress, 要求如下: 准备工作: VMware 14 CentOS 7.4 最小化 安装镜像 Wordpress 安装包, 下载 预热: 使用VMware新建4台虚拟机, ...
- 【BZOJ4383】[POI2015]pustynia
题意: 建议Alt+F4百度一下 题解: 差分约束+线段树优化建图,直接按照拓扑序跑就行了 代码: #include<iostream> #include<cstring> # ...
- c指针学习小结(参考别人总结的经验)
指针学习与总结一.1.int *p :p与*先结合,说明p是一个指针,然后与int结合说明指向的是一个int型的.2.int p[3] :p与[]结合说明p是一个数组,然后与int结合,说明数组里的元 ...
- 紫书 习题 8-25 UVa 11175 (结论证明)(配图)
看了这篇博客https://blog.csdn.net/u013520118/article/details/48032599 但是这篇里面没有写结论的证明, 我来证明一下. 首先结论是对于E图而言, ...
- redhat下搭建jdk+tomcat环境
由于redhat自带安装了jdk,我们需要现将其进行卸载 卸载系统自带的jdk版本: 查看自带的jdk: 输入命令:rpm -qa|grep gcj 可能看到如下类似的信息: libgcj-4.1.2 ...