3DES(Triple DES)算法是由DES算法演变而来的加密算法。3DES基于DES算法,通过增加密钥长度和多次迭代加密来提高安全性。3DES有三个可用的密钥,算法流程如下:首先使用
-
第一个密钥对数据进行DES加密。
B1 = E(M , K1);
2. 然后使用第二个密钥对加密后的数据进行DES解密。
B2 = D(B1 , K2);
3. 最后再使用第三个密钥再对解密后的数据进行DES加密。
B3 = E(B2 , K3);
3DES支持多种加密模式,包括ECB、CBC、CFB和OFB等。其中ECB模式是最简单的一种模式,它将数据分成若干个固定长度的块(通常是8个字节),然后对每个块独立进行加密和解密。ECB模式存在的主要问题是数据块的重复加密,同一个明文块使用相同的密钥加密后会得到相同的密文块,这样就有可能被攻击者利用,对数据造成破坏。
下面是ECB在OpenSSL库下面使用
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <openssl/des.h>
#define BLOCK_SIZE 8
void printHex(const char *title, unsigned char *buffer, long size)
{
int i;
printf("%s :\n",title);
for(i=0;i<size;i++)
{
/*if(i%16 == 0)
printf("\n");*/