简单的C#中的RSA的用法
来源:互联网 发布:php eol 有什么用处 编辑:程序博客网 时间:2024/05/18 17:27
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 的公钥
Console.WriteLine("公钥是: "+publickey);
string plaintext;
plaintext="01"; //原始数据
Console.WriteLine("原始数据是: {0} ",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(" ");
/**//*//////////////////////////////////////////////*/
//rsa1开始解密
byte[] plaintbytes;
plaintbytes = rsa1.Decrypt(cipherbytes,false);
Console.WriteLine("解密后的数据是:");
Console.WriteLine(Encoding.UTF8.GetString(plaintbytes));
Console.ReadLine();
}
}
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 的公钥
Console.WriteLine("公钥是: "+publickey);
string plaintext;
plaintext="01"; //原始数据
Console.WriteLine("原始数据是: {0} ",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(" ");
/**//*//////////////////////////////////////////////*/
//rsa1开始解密
byte[] plaintbytes;
plaintbytes = rsa1.Decrypt(cipherbytes,false);
Console.WriteLine("解密后的数据是:");
Console.WriteLine(Encoding.UTF8.GetString(plaintbytes));
Console.ReadLine();
}
}
- 简单的C#中的RSA的用法
- 关于c#中的Timer控件的简单用法
- 关于c#中的Timer控件的简单用法
- 关于c#中的Timer控件的简单用法
- 关于c#中的Timer控件的简单用法
- 关于c#中的Timer控件的简单用法
- C#中的索引器的简单理解和用法
- C#中文RSA加密解密的简单方式
- C#字符串的简单用法
- c# ajax的简单用法
- c# ToolTip的简单用法
- C# ThreadPool的简单用法
- c#中的messageBox的用法
- C#中的foreach的用法
- C#与Java的RSA
- RSA加密算法的简单实现
- RSA的简单模拟实现
- RSA算法的简单实现
- JDBC 概述
- 关于Applet利用数字签名获得本地访问权限的问题
- map24根据经纬度查找地方
- 我的论文被计算机工程与应用录用了
- 今天开设个人博客,作为我的学习笔记
- 简单的C#中的RSA的用法
- js中的所有鼠标事件
- Eclipse插件安装的三种方法
- sql server 2000 的数据类型
- Java对数据库操作中,PrepareStatement的Statement的区别
- map24根据两个地方的经纬度来获取路径
- 威客模式终极公式
- Interface Parameter
- SQL 和 MDX 比较