转自
http://blog.sina.com.cn/s/blog_4c7ab7a601009884.html
http://www.blogjava.net/amigoxie/archive/2014/07/06/415503.html
http://www.hankcs.com/security/des-algorithm-illustrated.html
这一篇文章要解决数据加密——数据补位的问题、DES算法的两种模式ECB和CBC问题以及更加安全的算法——3DES算法。
一、数据补位
DES数据加解密就是将数据按照8个字节一段进行DES加密或解密得到一段8个字节的密文或者明文,最后一段不足8个字节,按照需求补足8个字节(通常补00或者FF,根据实际要求不同)进行计算,之后按照顺序将计算所得的数据连在一起即可。
这里有个问题就是为什么要进行数据补位?主要原因是DES算法加解密时要求数据必须为8个字节。
二、ECB模式
DES ECB(电子密本方式)其实非常简单,就是将数据按照8个字节一段进行DES加密或解密得到一段8个字节的密文或者明文,最后一段不足8个字节,按照需求补足8个字节进行计算,之后按照顺序将计算所得的数据连在一起即可,各段数据之间互不影响。
三、CBC模式
DES CBC(密文分组链接方式)有点麻烦,它的实现机制使加密的各段数据之间有了联系。其实现的机理如下:
加密步骤如下:
1)首先将数据按照8个字节一组进行分组得到D1D2......Dn(若数据不是8的整数倍,用指定的PADDING数据补位)
2)第一组数据D1与初始化向量I异或后的结果进行DES加密得到第一组密文C1(初始化向量I为全零)
3)第二组数据D2与第一组的加密结果C1异或以后的结果进行DES加密,得到第二组密文C2
4)之后的数据以此类推,得到Cn
5)按顺序连为C1C2C3......Cn即为加密结果。
解密是加密的逆过程,步骤如下:
1)首先将数据按照8个字节一组进行分组得到C1C2C3......Cn
2)将第一组数据进行解密后与初始化向量I进行异或得到第一组明文D1(注意:一定是先解密再异或)
3)将第二组数据C2进行解密后与第一组密文数据进行异或得到第二组数据D2
4)之后依此类推,得到Dn
5)按顺序连为D1D2D3......Dn即为解密结果。
这里注意一点,解密的结果并不一定是我们原来的加密数据,可能还含有你补得位,一定要把补位去掉才是你的原来的数据。
四、3DES 算法
3DES算法顾名思义就是3次DES算法,其算法原理如下:
设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的密钥,P代表明文,C代表密表,这样,
3DES加密过程为:C=Ek3(Dk2(Ek1(P)))
3DES解密过程为:P=Dk1((EK2(Dk3(C)))
这里可以K1=K3,但不能K1=K2=K3(如果相等的话就成了DES算法了)
3DES with 2 diffrent keys(K1=K3),可以是3DES-CBC,也可以是3DES-ECB,3DES-CBC整个算法的流程和DES-CBC一样,但是在原来的加密或者解密处增加了异或运算的步骤,使用的密钥是16字节长度的密钥,将密钥分成左8字节和右8字节的两部分,即k1=左8字节,k2=右8字节,然后进行加密运算和解密运算。
3DES with 3 different keys,和3DES-CBC的流程完全一样,只是使用的密钥是24字节的,但在每个加密解密加密时候用的密钥不一样,将密钥分为3段8字节的密钥分别为密钥1、密钥2、密钥3,在3DES加密时对加密解密加密依次使用密钥1、密钥2、密钥3,在3DES解密时对解密加密解密依次使用密钥3、密钥2、密钥1。
分享到:
相关推荐
AES,全称为“高级加密标准”(Advanced Encryption Standard),是目前最广泛使用的对称加密算法之一。它基于替换和置换的组合,采用分组密码设计原理,以128位为基本处理单元,支持128、192和256位的密钥长度。AES...
首先,DES是一种对称加密算法,由IBM在1970年代开发,并在1977年被美国国家标准局采纳为标准。它基于64位的密钥和64位的数据块进行操作,但实际只有56位的密钥有效,因为它包含了8位的奇偶校验位。尽管DES在当时是一...
2、DES-ECB加密/解密、DES-CBC加密/解密 3、3DES-ECB加密/解密、3DES-CBC加密/解密 4、内含测试程序,在Linux环境下进入目录后make即可编译,已经在ubuntu16.04环境下编译测试OK; 5、3DES,即TDES,三重数据加密...
**DES加解密工具**:这些工具通常包括了对明文数据进行DES、TDES加密和解密的功能,支持不同工作模式如ECB和CBC。它们可以帮助用户快速实现数据的加密和解密,确保数据的安全传输。例如,提供的"DES加解密工具"和...
DES是一种广泛使用的对称加密算法,用于保护数据的安全性。在Delphi中,开发人员可以使用内置的TDes组件或者自定义代码来实现DES加密和解密功能。 描述中的"delphi DES 加密,解密 十分清楚,有用"提示我们,这个...
DES(数据加密标准)是一种对称加密算法,由IBM在1970年代初开发,后被美国政府采纳为联邦信息处理标准(FIPS)。它基于64位的数据块和56位的密钥进行操作,通过一系列复杂的置换和异或运算,将明文转换为密文。由于...
AES是一种广泛使用的对称加密算法,适用于大量数据的快速加密。在Delphi中,可以使用Trijind.AES库来实现AES加密解密。该库提供了AES的ECB(电子密码本)、CBC(密文块链接)、CFB(密文反馈)和OFB(输出反馈)模式...
包括DES(Data Encryption Standard)、TDES(Triple DES,即3DES)、AES(Advanced Encryption Standard)、ARC4(Arcfour,一种流密码)以及HASH(哈希函数)和RSA(Rivest-Shamir-Adleman,非对称加密算法)。...
3DES是一种对称加密算法,它基于DES(Data Encryption Standard)算法,通过三次迭代来提高安全性。本篇文章将深入探讨如何在C#中实现3DES的加密和解密过程。 首先,我们需要了解3DES的工作原理。3DES使用了三个...
4. 加密和解密:使用`DES_ecb_encrypt`进行单块数据的加密和解密,或者使用`DES_cbc_encrypt`进行CBC(Cipher Block Chaining)模式的加密和解密,该模式能够解决明文模式的弱点。 5. 销毁密钥:在完成加密操作后,...
尽管由于密钥长度较短,DES 已不再被广泛使用,但它仍然是理解和学习对称加密算法的一个很好的起点。 ##### 2.2 DES 加密算法的实现 Python 中实现 DES 加密算法通常需要借助第三方库,例如 `pycryptodome` 或者 `...
例如,DES/TDES算法支持ECB和CBC模式,而AES算法支持多种模式和密钥长度,其中AES-128、AES-192、AES-256硬件加速功能对于性能要求较高的场合十分有用。 总之,STM32微控制器通过内置的硬件安全模块和丰富的加密算...
CryptoJS是JavaScript库,用于加密和解密数据,它提供了多种加密算法,包括对称加密(如AES、DES、TDES)和非对称加密(如RSA)。此压缩包包含了CryptoJS的两个版本:v3.1.2-master和v4.1.1。在前端开发中,由于数据...
这个库包含了对两种主流的对称加密算法的支持:高级加密标准(AES)和三重数据加密标准(TDES)。这些加密技术在嵌入式系统中广泛应用于数据保护、通信安全以及存储数据的加密。 AES(Advanced Encryption Standard...
STM32F2系列提供了加密处理器,支持多种对称加密算法,如DES、TDES和AES。它支持不同的工作模式,包括电子密码本模式(ECB)、密码块链接模式(CBC)和计数模式(CTR)。加密处理器内嵌有FIFO和DMA支持,可以在AHB2...