webdn
 
  首页     免费截图     VIP会员区     广告Banner     技术文档     网站模板  
网站截图,网站每日新 !
网页模板

首页 >> WebDN 文档 >> 网络编程 >> ASP.net 技术资料 >> Page 18 >> 用.NET非对称加密算法实例

 

用.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();
 }

}



电话咨询:010-60520722 QQ咨询:3792656   |   583696287   |   66733350 关于WebDN  |  站点地图  |  联系我们  |  支付方式  |  友情链接
© 2004-2008 WebDN.com 版权所有. 沪ICP备05040479号