加密它:用新的高级加密标准(AES)保持你的数据安全

2016-01-29 12:13 66 1 收藏

加密它:用新的高级加密标准(AES)保持你的数据安全,加密它:用新的高级加密标准(AES)保持你的数据安全

【 tulaoshi.com - C语言心得技巧 】

加密它:用新的高级加密标准(AES)保持你的数据安全


原著:James McCaffrey

翻译:小刀人
 

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)

原文出处:MSDN Magazine November 2003 (Encrypt It)

本文的代码下载:msdnmag200311AES.exe (143KB)

本文假设你熟悉 C# 和 位(bit)操作。

摘要

  AES(The Advanced Encryption Standard)是美国国家标准与技术研究所用于加密电子数据的规范。它被预期能成为人们公认的加密包括金融、电信和政府数字信息的方法。本文展示了AES的概貌并解析了它使用的算法。包括一个完整的C#实现和加密.NET数据的举例。在读完本文后你将能用AES加密、测试 基于AES的软件并能在你的系统中使用AES加密。
 

  美国国家标准与技术研究所(NIST)在2002年5月26日建立了新的高级数据加密标准(AES)规范。本文中我将提供一个用C#编写的的能运行的 AES 实现,并详细解释到底什么是 AES 以及编码是如何工作的。我将向您展示如何用 AES 加密数据并扩展本文给出的代码来开发一个商业级质量的 AES 类。我 还将解释怎样把 AES 结合到你的软件系统中去和为什么要这么做,以及如何测试基于 AES 的软件。
  注意本文提供的代码和基于本文的任何其它的实现都在联邦加密模块出口控制的适用范围之内(详情请参看 Commercial Encryption Export Controls )。
  AES 是一个新的可以用于保护电子数据的加密算法。明确地说,AES 是一个迭代的、对称密钥分组的密码,它可以使用128、192 和 256 位密钥,并且用 128 位(16字节)分组加密和解密数据。与公共密钥密码使用密钥对不同,对称密钥密码使用相同的密钥加密和解密数据。通过分组密码返回的加密数据 的位数与输入数据相同。迭代加密使用一个循环结构,在该循环中重复置换(permutations )和替换(substitutions)输入数据。Figure 1 显示了 AES 用192位密钥对一个16位字节数据块进行加密和解密的情形。


Figure 1 部分数据

AES算法概述

  AES 算法是基于置换和代替的。置换是数据的重新排列,而代替是用一个单元数据替换另一个。AES 使用了几种不同的技术来实现置换和替换。为了阐明这些技术,让我们用 Figure 1 所示的数据讨论一个具体的 AES 加密例子。下面是你要加密的128位值以及它们对应的索引数组:

00 11 22 33 44 55 66 77 88 99 aa bb cc dd ee ff0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

192位密钥的值是:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com)
00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f 10 11 12 13 14 15 16 170 1 2 3 4 5 6 7 8 9 10 1112 13 14 15 16 17 18 19 20 21 22 23


Figure 2 S-盒( Sbox )

当 AES 的构造函数(constructor)被调用时,用于加密方法的两个表被初始化。第一个表是代替盒称为S-盒。它是一个16×16的矩阵。S-盒的前五行和前五列如 Figure 2 所示。在幕后,加密例程获取该密钥数组并用它来生成一个名为w[]的密钥调度表,Figure 3 所示。


Figure 3 密钥调度表(Key Sched)

w[] 最初的 Nk (6) 行被作为种子,用原始密钥值(0x00 到0x17)。剩余行从种子密钥来产生。变量 Nk 代表以 32 位字为单位的种子密钥长度。稍后我分析 AES 实现时你将清楚地看到 w[] 是怎样产生的。 关键是这里现在有许多密钥使用而不只是一个。这些新的密钥被称为轮密钥(round keys)以将它们与原始种子密钥区别开来。


Figure 4 State (态)数组

  AES 加密例程开始是拷贝 16 字节的输入数组到一个名为  State (态)的 4×4 字节矩阵中。(

来源:https://www.tulaoshi.com/n/20160129/1485115.html

延伸阅读
标签: 电脑入门
本软件是一个功能强大、安全高效,简单易用的数据加密和保护软件。 它有超快和最强的文件夹,文件加密功能、数据保护功能,文件夹、文件的粉碎删除以及文件夹伪装等功能。 1、运行软件 双击桌面上的图标 或者点击开始→程序→超级加密3000→超级加密3000即可运行该软件。进入软件主界面。 超级加密3000的界面有点类似于资...
VisualBasic的RND()函数有一个重要的特征:当RND()的参数(我们称这里可以称它为种子)为负值时,同一种子(负值)产生同一个随机数序列。同时VisualBasic还具有强大的二进制技术功能,这样我们可以按以下思路实现文件内容加密: X=RND(-KEY)'KEY为正数 VAULE=INT(256*RND)'产生一个随机数(以此为密码) OpenFILENAME$ForBin...
标签: Web开发
数据加密在我们生活中的地位已经越来越重要了,尤其是考虑到在网络上发生的大量交易和传输的大量数据。如果对于采用安全措施有兴趣的话,也一定会有兴趣了解PHP提供的一系列安全功能。在本篇文章中,我们将介绍这些功能,提供一些基本的用法,以便你能够为自己的应用软件中增加安全功能。预备知识在详细介绍PHP的安全功能之前,我们需要花点...
标签: ASP
你是怎麼把密碼儲存到資料庫裡?是以純文字的方式?你可知道這對安全的危險性?當攻擊你網站的人能開啟資料庫瀏覽,以純文字方式存在資料庫裡的密碼一覽無疑,基於安全上的考量,你想這樣適當嗎?有什麼辦法能夠讓別人看到資料庫裡的資料,也沒辦法知道儲存在其中的密碼? 以上問題你是否知道如何解決?本文要告訴你,如何將你的密碼做加密處...
Oracle 9i2 特色功能: 1、返回值为自定义对象类型的函数。例如SDO_GEOMETRY数据类型。 2、可以用Java或C语言编写存储过程。÷ Oracle Spatial 高级功能: 可以使用返回值为SDO_GEOMETRY数据类型的自定义函数作为几何列获取空间数据。 加密实现: 1、简单的数据加密。 1)创建返回值为SDO_GEOMETRY数据...

经验教程

191

收藏

59
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部