.NET中的密码学--对称加密(下)

原创 2004年01月14日 11:02:00

上接http://www.csdn.net/Develop/read_article.asp?id=23386

代码例子

      现在我们有足够关于SymmetricAlgorithm信息。最后,让我们看看将要编码和解码的代码片断。我假设你拥有一个包含txtData和命令按钮控件的窗体。在命令按钮的代码事件里写如下代码。这个代码将要加密TextBox里面的文本并用MessageBox显示,在将加密结果写回到TextBox中。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

SymmetricAlgorithm mCryptProv;

MemoryStream mMemStr;

// 加密txtData中的数据,然后将加密结果用MessageBox显示并且回写到TextBox

// 这里你可以配置任何.NET支持的类

DES mCryptProv = SymmetricAlgorithm.Create(“Rijndael”);

// 加密数据将要以流的形式存储在内存中因此我们需要内存Stream对象

mMemStr = new MemoryStream();

// 创建ICryptTransform对象.(在这里我们使用默认的密钥和初始向量).

ICryptTramsform mTransform = mCryptProv.CreateEncryptor();

CryptoStream mCSWriter = new CryptoStream(mMemStr,mTransform,CryptoStreamMode.Write);

StreamWriter mSWriter = StreamWriter(mCSWriter);

mSwriter.Writer(this.txtData.Text);

mSWriter.Flush();

mCSWriter.FlushFinalBlock();

      有一件事情在这里需要注意我们没有在代码的任何地方使用IV和密钥。事实上,在我们在代码里面没有指定他们的时候.NET Framework将为我们自动产生。但是本文包含的例子代码使用的是用户指定的密钥和IV。我们将加密以后的数据使用MemoryStream写到内存中。现在让我们从内存中得到数据的代码。

// 数据已经写入内存但是我们需要回显它到TextBoxMessageBox中,因此要做下面的工作。

// 为接受数据创建字节数组。

byte[] mBytes = new byte[mMemStr.Length - 1];

mMemStr.Position = 0;

mMemStr.Read(mBytes,0,mMemStr.Length);

Text.UTF8Encoding mEnc = new Text.UTF8Encoding();

String mEncData = mEnc.GetString(mBytes);

MessageBox.Show(“加密数据为:/n”+mEncData);

This.txtData.Text = mEncData;

从字节转换为字符串必须要编码。在这里我使用了UTF8Encoding。最后,让我们将解密后的数据再次显示在MessageBoxTextBox中。

// 现在让我们从内存中得到解密后的数据

// 因为我们的数据在内存中,所以我们需要重新使用MemoryStream对象。

// 将内存点置0

mMemStr.Position = 0;

mTransform = mCryptProv.CreateDecryptor();

CryptoStream mCSReader = new CryptoStream(mMemStr,mTransform,CryptoStreamMode.Read);

StreamReader mStrReader = new StreamReader(mCSReader);

String mDecData = mStrReader.ReadToEnd();

MessageBox(“解密数据为:/n”+mDecData);

This.txtData.Text = mDecData;

      这是所有的工作。解密那些数据我们使用了相同的内存流。为了能从流的其实部分读数据我们首先将它置为开始。然后我们用SymmetricAlgorithm对象的CreateDecryptor方法创建IcryptoTransform对象。我们在上面的代码中为了解密重复使用了对象(mMemStr)。你可以创建新的对象(使用新的变量)。然后我们为了从内存中读取数据需要StreamReader对象。While reading that it will also decrypt that data since we passed CryptoStream object during the creation of StreamReader object.

最后的话

      .NET为我们提供了一个非常好的托管途径保护我们的数据。我们可以使用.NET内建的一组类来加密我们的数据。虽然很多的类后台依然使用Crypto APIs技术,我们使用老的Crypto APIs没有任何问题。但是我们可以不用担心那些类的具体实现来安全的使用这些类。在后面的文章我将描述非对称加密算法的神话和用途。

关于例子

      该文章的例子代码让你可以选择一个算法来加密或者解密数据。而且它还让你指定你自己的IV和密钥。代码以两种方式工作。一种是TextBox,意思是你在TextBox中写些东西然后加密或者解密这些内容。第二种,你可以选择要加密或者解密的文件。

密码学的对称加密和不对称加密有哪些和各自特点

在对称加密算法中,数据发信方将明文(原始数据)和加密密钥一起经过特殊加密算法处理后,使其变成复杂的加密密文发送出去。收信方收到密文后,若想解读原文,则需要使用加密用过的密钥及相同算法的逆算法对密文进行...
  • lingzhm
  • lingzhm
  • 2015年09月10日 21:28
  • 1580

非对称加密 RSA加密算法原理简述

估计密码学一段时间内多不会有什么更新了。 非对称加密: 非对称加密是与对称加密完全相反的概念,对称加密指的是加密解密使用的是同样的密钥Key,如流加密,块加密,一次性密码本之类的。而非对称...
  • jerry81333
  • jerry81333
  • 2016年10月24日 08:54
  • 2116

.Net加密与解密——对称加密

一,思路       对称加密含有一个被称为密钥的东西,在消息发送前使用密钥对消息进行加密,得到密文并发送,接收方收到密文后,使用相同的密钥进行解密,获得原消息。   PS:使用密钥对消息进行加密的...
  • lhc2207221755
  • lhc2207221755
  • 2015年05月17日 16:56
  • 1292

.NET中的密码学--对称加密

在.NET之前,使用非托管的Win32APIs加密解密数据是一件非常痛苦的事情。为了这个加密解密的目的,.NET配置了一组类(和命名空间)。现在你有很多类可以使用每种不同的算法保护你的数据。在.NET...
  • gdn_wolf
  • gdn_wolf
  • 2012年03月10日 08:13
  • 465

Java密码学对称加密Demo

  • 2012年12月27日 13:50
  • 28KB
  • 下载

公钥密码学中的素数以及对称加密

转来的科普文章。    密码学,一向被人们认为门槛很高,特别高端...这也是实际,但是这决不意味着普通人无法了解它的精髓,对于喜欢画圆的人来讲,即便是理解了密码技术背后的哪怕一点理论...
  • ssmile
  • ssmile
  • 2016年12月01日 16:31
  • 866

公钥密码学中的素数以及对称加密

密码学,一向被人们认为门槛很高,特别高端...这也是实际,但是这决不意味着普通人无法了解它的精髓,对于喜欢画圆的人来讲,即便是理解了密码技术背后的哪怕一点理论,也是激动人心的。声明和悲叹最近,一次联调...
  • dog250
  • dog250
  • 2014年08月31日 10:34
  • 7159

软件密码学基础---非对称加密

1、基础密钥对:公钥和私钥; 特点:如果用公钥对数据进行加密,只有用对应的私钥才能解密;如果用私钥对数据进行加密,那么只有用对应的公钥才能解密; 一般:公钥用来加密信息,私钥用来数字签名;2、通信...
  • bh_xiaoxinba
  • bh_xiaoxinba
  • 2017年06月25日 23:57
  • 181

ASP.NET MVC中使用JS实现不对称加密密码传输

ASP.NET MVC中登录页面中点击登录后,用户名、密码将被明文传输到Controller中,使用Fiddler等工具可以轻松截获并获取密码, 这是不安全的。 使用对称加密,如AES,密钥将被暴露前...
  • fanrong1985
  • fanrong1985
  • 2017年07月14日 05:25
  • 686

java密码学学习整理--对称加密(着重描述3des)

对称加密及密钥的管理(对实践的小结)
  • gufachongyang02
  • gufachongyang02
  • 2014年05月15日 22:08
  • 977
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:.NET中的密码学--对称加密(下)
举报原因:
原因补充:

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