简单的使用.NET非对称加密算法的例子

王朝c#·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

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

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航