使用对称加密算法的例子

原创 2006年05月26日 13:57:00

using System;
using System.Security.Cryptography;
using System.Text;
using System.IO;

/// <summary>
/// 使用对称加密算法的例子
/// </summary>
class Class2
{

 static void Main(string[] args)
 {
  Class2 c=new Class2();
  c.StartDemo();
 }

 public void StartDemo()
 {
  //establish symmetric algorithm
  SymmetricAlgorithm sa = Rijndael.Create();

  //key and iv
  sa.GenerateKey();    //产生随机的 (32*8) 位的密钥
  //sa.GenerateIV();    //初始向量,在ECB模式里面可以不用IV
  sa.Mode = CipherMode.ECB;  //块处理模式
  sa.Padding = PaddingMode.Zeros; //末尾数据块的填充模式

  
  Console.WriteLine("密钥是:");   ///////////
  for (int i=0; i<sa.Key.Length; i++)  ///////////
  {          ///////////
   Console.Write("{0:X2} ",sa.Key[i]); ///////////
  }          ///////////
  Console.WriteLine("/n");    ///////////


  //establish crypto stream
  MemoryStream ms = new MemoryStream();
  CryptoStream cs = new CryptoStream(ms,sa.CreateEncryptor(),CryptoStreamMode.Write);

  //
  string plaintext; //原始文本
  byte[] cipherbytes; //加密后的数据
  byte[] finalbytes;  //解密后的数据

  plaintext="How are you? 这是一行文字。";
  byte[] plainbytes = Encoding.UTF8.GetBytes(plaintext);


  Console.WriteLine("原始文本是:/n{0}/n",plaintext);
  //display plaint text byte array in hex format
  Console.WriteLine("原始数据是:");   ///////////
  for (int i=0; i<plainbytes.Length; i++)  ///////////
  {           ///////////
   Console.Write("{0:X2} ",plainbytes[i]); ///////////
  }           ///////////
  Console.WriteLine("/n");     ///////////

  //加密过程
  cs.Write(plainbytes, 0, plainbytes.Length);
  cs.Close();
  cipherbytes = ms.ToArray();
  ms.Close();

  //display ciphertext byte array in hex format
  Console.WriteLine("加密后的数据是:");  ///////////
  for (int i=0; i<cipherbytes.Length; i++) ///////////
  {           ///////////
   Console.Write("{0:X2} ",cipherbytes[i]);///////////
  }           ///////////
  Console.WriteLine("/n");     ///////////


  //下面的为加密过程
  ms=new MemoryStream(cipherbytes);
  cs=new CryptoStream(ms,sa.CreateDecryptor(),CryptoStreamMode.Read);
  finalbytes=new byte[plainbytes.Length];
  cs.Read(finalbytes,0,plainbytes.Length);

  Console.WriteLine("解密后的数据是:");  ///////////
  for (int i=0; i<finalbytes.Length; i++)     ///////////
  {           ///////////
   Console.Write("{0:X2} ",finalbytes[i]); ///////////
  }           ///////////
  Console.WriteLine("/n");     ///////////

  string finaltext=Encoding.UTF8.GetString(finalbytes);

  Console.WriteLine("解密后的文本是:/n{0}/n/n",finaltext );
  Console.WriteLine("按任意键继续......");
  Console.ReadLine();


 }
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

PHP 使用非对称加密算法 (RSA)

PHP 使用非对称加密算法 (RSA) 2016-06-02 PHPer IT小圈儿解释 「非对称加密算法」需要两个密钥:公钥(publickey)和私钥(privatekey)。公钥与私钥是一对,...

IDEA对称加密算法.zip

非对称加密算法

  • 2013-10-30 17:03
  • 224KB
  • 下载

密码学总结(三) 非对称加密算法

非对称加密算法RSA 基于大素数分解难题的加密算法取两个大素数p q,N=p*q,则根据欧拉定理的各种延伸,得f(N)=(p-1)(q-1)=pq-p-q+1 利用 定理为: 其中pi为不同的...

椭圆曲线非对称加密算法

  • 2013-03-12 19:26
  • 375KB
  • 下载

关于公钥私钥是否可以互相加解密的理解(附苹果开发者证书配置时非对称加密算法的应用)

查资料的时候发现很多人有疑惑,公钥和私钥到底哪个是用来加密,哪个是用来解密的,是否可以公钥加密私钥解密,同时也可以私钥加密公钥解密呢?针对这一问题,说下自己的理解。 首先要明确两个问题:(1)既可...

Aes对称加密算法原理

  • 2009-03-15 11:34
  • 187KB
  • 下载

ECC非对称加密算法

  • 2013-10-17 10:12
  • 123KB
  • 下载

简单理解非对称加密算法

最初理解非对称加密算法是一件很难的事,可能需要看一些晦涩难懂的读物看很长时间才能理解得了,所以今天我打算用一个简单的例子来解释非对称加密算法,希望可以帮助大家快速的理解这个概念。首先,我们设想这样一个...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)