前言:

本文只介绍How to use,对于加密算法的研究不予讨论。

关于私钥的存储,微软给的建议是使用windows自带的秘钥容器,相见文档

为了直观看到私钥和公钥,本文直接将其存入XML文件中。现实情况则要复杂的多,还牵涉到数字签名、数字证书等。

关于公钥、私钥、数字签名、数字证书的概念,相见阮一峰大神的博客,传送门在这里

正文:

由于RSA不适合加密大量数据,所以可以采用DES和RSA混合加密的方法,即先用DES加密数据,再用RSA加密DES的秘钥。

RSAHelper 类

public class RSAHelper
{
/// <summary>
/// 读取二进制文件
/// </summary>
/// <param name="path"></param>
/// <returns></returns>
public static byte[] GetByte(string path)
{
FileInfo fi = new FileInfo(path);
List<byte> buff = new List<byte>();
using (FileStream fs = fi.Open(FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
BinaryReader br = new BinaryReader(fs);
try
{
while (true)
{
byte i = br.ReadByte();
buff.Add(i);
}
}
catch (Exception)
{
br.Close();
}
}
return buff.ToArray();
} /// <summary>
/// 读取文本文件
/// </summary>
/// <param name="path"></param>
/// <returns></returns>
public static string GetText(string path)
{
FileInfo fi = new FileInfo(path);
string content;
using (FileStream fs = fi.Open(FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
StreamReader sr = new StreamReader(fs);
content = sr.ReadToEnd();
sr.Close();
}
return content;
} /// <summary>
/// 写入二进制文件
/// </summary>
/// <param name="content"></param>
/// <param name="path"></param>
public static void WriteByte(byte[] content, string path)
{
FileInfo fi = new FileInfo(path);
using (FileStream fs = fi.Open(FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
BinaryWriter br = new BinaryWriter(fs);
br.Write(content);
br.Flush();
br.Close();
}
} /// <summary>
/// 写入文本文件
/// </summary>
/// <param name="content"></param>
/// <param name="path"></param>
public static void WriteText(string content, string path)
{
FileInfo fi = new FileInfo(path);
using (FileStream fs = fi.Open(FileMode.OpenOrCreate, FileAccess.ReadWrite))
{
StreamWriter sw = new StreamWriter(fs);
sw.Write(content);
sw.Flush();
sw.Close();
}
} /// <summary>
/// RSA加密/解密
/// </summary>
/// <param name="data">加密/解密数据</param>
/// <param name="key">公钥/私钥</param>
/// <param name="isEncrypt">ture加密,false解密</param>
/// <returns></returns>
public static byte[] EncryptOrDecrypt(byte[] data, string key, bool isEncrypt)
{
RSACryptoServiceProvider rsaP = new RSACryptoServiceProvider();
rsaP.FromXmlString(key);
if (isEncrypt)// 加密
{
byte[] buff = rsaP.Encrypt(data, true);
return buff;
}
else // 解密
{
byte[] buff = rsaP.Decrypt(data, true);
return buff;
} }
}

RSAHelper类

DESHelper 类

public class DESHelper
{
/// <summary>
/// DES加密/解密
/// </summary>
/// <param name="data">加密/解密数据</param>
/// <param name="key">秘钥</param>
/// <param name="keyIV">向量</param>
/// <param name="isEncrypt">true加密,false解密</param>
/// <returns></returns>
public static byte[] EncryptOrDecrypt(byte[] data, byte[] key, byte[] keyIV, bool isEncrypt)
{
DESCryptoServiceProvider desP = new DESCryptoServiceProvider();
if (isEncrypt)// 加密
{
desP.Key = key;
desP.IV = keyIV;
ICryptoTransform desencrypt = desP.CreateEncryptor(key, keyIV);
byte[] result = desencrypt.TransformFinalBlock(data, , data.Length);
return result;
}
else // 解密
{
desP.Key = key;
desP.IV = keyIV;
ICryptoTransform desencrypt = desP.CreateDecryptor(key, keyIV);
byte[] result = desencrypt.TransformFinalBlock(data, , data.Length);
return result;
}
} /// <summary>
/// 创建随机秘钥
/// </summary>
/// <returns></returns>
public static byte[] CreateKey()
{
DESCryptoServiceProvider desP = new DESCryptoServiceProvider();
desP.GenerateKey();
return desP.Key;
} /// <summary>
/// 创建随机向量
/// </summary>
/// <returns></returns>
public static byte[] CreateIV()
{
DESCryptoServiceProvider desP = new DESCryptoServiceProvider();
desP.GenerateIV();
return desP.IV;
}
}

DESHelper类

主程序代码

class Program
{
static void Main(string[] args)
{
string rootPath = AppDomain.CurrentDomain.BaseDirectory;
string RSAPath = Path.Combine(rootPath, "RSA");
string encryptFilePath = Path.Combine(RSAPath, "加密文件.dll");
string decryptFilePath = Path.Combine(RSAPath, "解密文件.txt");
string publicKeyPath = Path.Combine(RSAPath, "RSA公钥.xml");
string privateKeyPath = Path.Combine(RSAPath, "RSA私钥.xml");
string DESKeyPath = Path.Combine(RSAPath, "经过RSA加密的DES秘钥.dll");
string DESIVPath = Path.Combine(RSAPath, "经过RSA加密的DES向量.dll");
if (Directory.Exists(RSAPath))
{
Directory.Delete(RSAPath, true);
}
Directory.CreateDirectory(RSAPath); Console.WriteLine("请输入要加密的内容:");
string data = Console.ReadLine(); RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
string RSAPublic = rsa.ToXmlString(false);// RSA公钥
string RSAPrivate = rsa.ToXmlString(true);// RSA私钥
byte[] DESKey = DESHelper.CreateKey(); // DES秘钥
byte[] DESIV = DESHelper.CreateIV(); // DES向量
// DES加密输入内容
byte[] enData = DESHelper.EncryptOrDecrypt(Encoding.Unicode.GetBytes(data), DESKey, DESIV, true);
// 写入加密文件
RSAHelper.WriteByte(enData, encryptFilePath);
// 写入RSA公钥
RSAHelper.WriteText(RSAPublic, publicKeyPath);
// 写入RSA私钥
RSAHelper.WriteText(RSAPrivate, privateKeyPath);
// 写入经过RSA加密的DES秘钥
RSAHelper.WriteByte(RSAHelper.EncryptOrDecrypt(DESKey, RSAPublic, true), DESKeyPath);
// 写入经过RSA加密的DES向量
RSAHelper.WriteByte(RSAHelper.EncryptOrDecrypt(DESIV, RSAPublic, true), DESIVPath); // 读取RSA私钥
string privateKey = RSAHelper.GetText(privateKeyPath);
// 读取DES秘钥并解密
byte[] realDESKey = RSAHelper.EncryptOrDecrypt(RSAHelper.GetByte(DESKeyPath), privateKey, false);
// 读取DES向量并解密
byte[] realDESIV = RSAHelper.EncryptOrDecrypt(RSAHelper.GetByte(DESIVPath), privateKey, false);
// 读取加密文件
byte[] enData2 = RSAHelper.GetByte(encryptFilePath);
// 解密文件
byte[] deData = DESHelper.EncryptOrDecrypt(enData2, realDESKey, realDESIV, false);
// 写入解密文件
RSAHelper.WriteText(Encoding.Unicode.GetString(deData), decryptFilePath); Console.WriteLine("加密成功!");
Console.ReadKey();
}
}

主程序代码

运行效果:

(完)

利用RSACryptoServiceProvider进行RSA加密解密的更多相关文章

  1. 利用openssl进行RSA加密解密

    openssl是一个功能强大的工具包,它集成了众多密码算法及实用工具.我们即可以利用它提供的命令台工具生成密钥.证书来加密解密文件,也可以在利用其提供的API接口在代码中对传输信息进行加密. RSA是 ...

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

    [转]C#中RSA加密解密和签名与验证的实现 RSA加密算法是一种非对称加密算法.在公钥加密标准和电子商业中RSA被广泛使用.RSA是1977年由罗纳德•李维斯特(Ron Rivest).阿迪•萨莫尔 ...

  3. 兼容javascript和C#的RSA加密解密算法,对web提交的数据进行加密传输

    Web应用中往往涉及到敏感的数据,由于HTTP协议以明文的形式与服务器进行交互,因此可以通过截获请求的数据包进行分析来盗取有用的信息.虽然https可以对传输的数据进行加密,但是必须要申请证书(一般都 ...

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

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

  5. C# Java间进行RSA加密解密交互(三)

    原文:C# Java间进行RSA加密解密交互(三) 接着前面一篇C# Java间进行RSA加密解密交互(二)说吧,在上篇中为了实现 /** * RSA加密 * @param text--待加密的明文 ...

  6. RSA加密解密和读取公钥、私钥

    /// <summary>     /// RSA加密解密及RSA签名和验证    /// </summary>     public class RSADE    {    ...

  7. C#的RSA加密解密签名,就为了支持PEM PKCS#8格式密钥对的导入导出

    差点造了一整个轮子 .Net Framework 4.5 里面的RSA功能,并未提供简单对PEM密钥格式的支持(.Net Core有咩?),差点(还远着)造了一整个轮子,就为了支持PEM PKCS#8 ...

  8. RSA加密解密及RSA签名和验证及证书

    RSA加密解密及RSA签名和验证及证书 公钥是给别人的 发送密文使用公钥加密 验证签名使用公钥验证 私钥是自己保留的 接受密文使用私钥解密 发送签名使用私钥签名 上述过程逆转是不行的,比如使用私钥加密 ...

  9. C# javascript 采用 RSA 加密解密

    C# javascript 采用 RSA 加密解密 1.C#提供公钥 2.javascript用公钥加密 3.C#用私钥解密 4.javascript 类库 https://www.pidder.de ...

随机推荐

  1. 剑指offer【01】- 二维数组中的查找(Java)

    在经历了春招各大公司的笔试题和面试官的血虐之后,决定要刷一些算法题了,不然连面试机会都没有. 而应对笔试和面试,比较出名的就是剑指offer的题目和LeetCode的题目了.剑指offer应对面试中的 ...

  2. centos 7 添加windows 字体

    环境: centos 7 mono 5.2  Asp.net MVC5 问题: 在生成验证码时报,验证码无法显示,字体集找不到 解决: 到windows 系统中,拷贝字体到centos中. windo ...

  3. Neo4j使用Cypher查询图形数据

    Neo4j使用Cypher查询图形数据,Cypher是描述性的图形查询语言,语法简单,功能强大,由于Neo4j在图形数据库家族中处于绝对领先的地位,拥有众多的用户基数,使得Cypher成为图形查询语言 ...

  4. ubuntu16.04 程序开机自启动设置及启动优化

    使用过程中,为了方便使用,有一些程序需要开机时自启动应用,下面将介绍一下ubuntu16.04下程序的开机自启动设置方法. 1  建立一个可执行程序的运行脚本如 keepalive.sh.内部写入要执 ...

  5. Android并发编程 多线程与锁

    该文章是一个系列文章,是本人在Android开发的漫漫长途上的一点感想和记录,如果能给各位看官带来一丝启发或者帮助,那真是极好的. 前言 前一篇Android并发编程开篇呢,主要是简单介绍一下线程以及 ...

  6. rfc2818 --- HTTP Over TLS

    协议链接 本协议描述了如何使用TLS来对Internet上的HTTP进行安全加固. 2.1. Connection Initiation(链接初始化) HTTP client同时也作为TLS clie ...

  7. 和我一起打造个简单搜索之SpringDataElasticSearch关键词高亮

    前面几篇文章详细讲解了 ElasticSearch 的搭建以及使用 SpringDataElasticSearch 来完成搜索查询,但是搜索一般都会有搜索关键字高亮的功能,今天我们把它给加上. 系列文 ...

  8. 内核开发知识第二讲,编写Kerner 程序中注意的问题.

    一丶函数多线程的安全问题 什么是函数多线程安全. 简单来说就是 ,一个函数在调用过程中.还没有返回的时候.再次被其他线程调用了.但是函数执行的结果是可靠的.就可以了说这个函数是安全的. 比如我们在用户 ...

  9. shiro源码篇 - shiro的session共享,你值得拥有

    前言 开心一刻 老师对小明说:"乳就是小的意思,比如乳猪就是小猪,乳名就是小名,请你用乳字造个句" 小明:"我家很穷,只能住在40平米的乳房" 老师:" ...

  10. 解决使用elementUI框架el-upload上传组件时session丢失问题

    在使用elementui框架上传组件的时候,出现session丢失,后端无法获取到sessionid,导致返回状态为未登陆 查看请求头缺少cookie值 上传组件代码: <el-upload c ...