用.NET非对称加密算法实例
来源:互联网 发布:沧海武功最强 知乎 编辑:程序博客网 时间:2024/06/06 09:39
用.NET非对称加密算法实例
【摘 要】一个简单的使用.NET非对称加密算法的例子, 本例的程序很简单,仅用于说明如何在.NET里面使用非对称(RSA)算法。
using System;
using System.IO;
using System.Text;
using System.Security.Cryptography;
/// <summary>
/// 一个简单的使用.NET非对称加密算法的例子
/// 本例的程序很简单,仅用于说明如何在.NET里面使用非对称(RSA)算法。
/// Kwanhong 2005.9
/// </summary>
class Class1
{
public static void Main(string[] args)
{
Class1 c=new Class1();
c.StartDemo();
}
public void StartDemo()
{
//RSA的加解密过程:
// 有 rsa1 和 rsa2 两个RSA对象。
// 现在要 rsa2 发送一段信息给 rsa1, 则先由 rsa1 发送“公钥”给 rsa2
// rsa2 获取得公钥之后,用来加密要发送的数据内容。
// rsa1 获取加密后的内容后,用自己的私钥解密,得出原始的数据内容。
RSACryptoServiceProvider rsa1 = new RSACryptoServiceProvider();
RSACryptoServiceProvider rsa2 = new RSACryptoServiceProvider();
string publickey;
publickey=rsa1.ToXmlString(false); //导出 rsa1 的公钥
string plaintext;
plaintext="你好吗?这是用于测试的字符串。"; //原始数据
Console.WriteLine("原始数据是:/n{0}/n",plaintext);
rsa2.FromXmlString(publickey); //rsa2 导入 rsa1 的公钥,用于加密信息
//rsa2开始加密
byte[] cipherbytes;
cipherbytes=rsa2.Encrypt(
Encoding.UTF8.GetBytes(plaintext),
false);
/*//////////////////////////////////////////////*/
Console.WriteLine("加密后的数据是:");
for(int i=0; i< cipherbytes.Length; i++)
{
Console.Write("{0:X2} ",cipherbytes[i]);
}
Console.WriteLine("/n");
/*//////////////////////////////////////////////*/
//rsa1开始解密
byte[] plaintbytes;
plaintbytes = rsa1.Decrypt(cipherbytes,false);
Console.WriteLine("解密后的数据是:");
Console.WriteLine(Encoding.UTF8.GetString(plaintbytes));
Console.ReadLine();
}
}
- 用.NET非对称加密算法实例
- 用.NET非对称加密算法实例
- 用.NET非对称加密算法实例
- 对称加密算法,非对称加密算法
- 对称加密算法,非对称加密算法
- 对称加密算法,非对称加密算法
- "对称/非对称密钥"加密算法
- "对称/非对称密钥"加密算法
- 非对称加密算法 DSA
- 非对称加密算法
- 非对称加密算法
- 非对称加密算法
- 非对称加密算法
- (转)非对称加密算法
- 非对称加密算法
- 非对称加密算法RSA
- 非对称加密算法理解
- 非对称加密算法 数字签名
- ASP代码开发规范
- 对称加密解密通用类库函数
- ASP面向对象编程探讨及比较
- 数据加密算法
- C++ 虚函数 多态
- 用.NET非对称加密算法实例
- 用.NET非对称加密算法实例
- 比较高效的一种分页方法
- Google收购了JotSpot
- 使用Apache Commons-email组件发送邮件
- 年轻程序员的迷茫
- 五一给儿子照的相片一张
- 初试正则表达式
- 理解接口