资源简介
C语言 3DES、AES、RC6、TEA、RSA、MD5、SHA1、SHA256加密源码

代码片段和文件信息
#define BPOLY 0x1b //!< Lower 8 bits of (x^8+x^4+x^3+x+1) ie. (x^4+x^3+x+1).
#define BLOCKSIZE 16 //!< Block size in number of bytes.
#define KEY_COUNT 3
#if KEY_COUNT == 1
#define KEYBITS 128 //!< Use AES128.
#elif KEY_COUNT == 2
#define KEYBITS 192 //!< Use AES196.
#elif KEY_COUNT == 3
#define KEYBITS 256 //!< Use AES256.
#else
#error Use 1 2 or 3 keys!
#endif
#if KEYBITS == 128
#define ROUNDS 10 //!< Number of rounds.
#define KEYLENGTH 16 //!< Key length in number of bytes.
#elif KEYBITS == 192
#define ROUNDS 12 //!< Number of rounds.
#define KEYLENGTH 24 //!< // Key length in number of bytes.
#elif KEYBITS == 256
#define ROUNDS 14 //!< Number of rounds.
#define KEYLENGTH 32 //!< Key length in number of bytes.
#else
#error Key must be 128 192 or 256 bits!
#endif
#define EXPANDED_KEY_SIZE (BLOCKSIZE * (ROUNDS+1)) //!< 176 208 or 240 bytes.
unsigned char AES_Key_Table[32] =
{
0xd0 0x94 0x3f 0x8c 0x29 0x76 0x15 0xd8
0x20 0x40 0xe3 0x27 0x45 0xd8 0x48 0xad
0xea 0x8b 0x2a 0x73 0x16 0xe9 0xb0 0x49
0x45 0xb3 0x39 0x28 0x0a 0xc3 0x28 0x3c
};
unsigned char block1[256]; //!< Workspace 1.
unsigned char block2[256]; //!< Worksapce 2.
unsigned char tempbuf[256];
unsigned char *powTbl; //!< Final location of exponentiation lookup table.
unsigned char *logTbl; //!< Final location of logarithm lookup table.
unsigned char *sBox; //!< Final location of s-box.
unsigned char *sBoxInv; //!< Final location of inverse s-box.
unsigned char *expandedKey; //!< Final location of expanded key.
void CalcPowLog(unsigned char *powTbl unsigned char *logTbl)
{
unsigned char i = 0;
unsigned char t = 1;
do {
// Use 0x03 as root for exponentiation and logarithms.
powTbl[i] = t;
logTbl[t] = i;
i++;
// Muliply t by 3 in GF(2^8).
t ^= (t << 1) ^ (t & 0x80 ? BPOLY : 0);
}while( t != 1 ); // Cyclic properties ensure that i < 255.
powTbl[255] = powTbl[0]; // 255 = ‘-0‘ 254 = -1 etc.
}
void CalcSBox( unsigned char * sBox )
{
unsigned char i rot;
unsigned char temp;
unsigned char result;
// Fill all entries of sBox[].
i = 0;
do {
//Inverse in GF(2^8).
if( i > 0 )
{
temp = powTbl[ 255 - logTbl[i] ];
}
else
{
temp = 0;
}
// Affine transformation in GF(2).
result = temp ^ 0x63; // Start with adding a vector in GF(2).
for( rot = 0; rot < 4; rot++ )
{
// Rotate left.
temp = (temp<<1) | (temp>>7);
// Add rotated byte in GF(2).
result ^= temp;
}
// Put result in table.
sBox[i] = result;
} while( ++i != 0 );
}
void CalcSBoxInv( unsigned char * sBox unsigned char * sBoxInv )
{
unsigned char i = 0;
unsigned char j = 0;
// Iterate through all elements in sBoxInv using i.
do {
// Search through sBox using j.
do {
// Check if current j is the inverse of current i.
if( sBox[ j ] == i )
{
// If s
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 11630 2012-04-12 20:55 MD5.C
文件 4863 2012-04-12 21:31 RC6.C
文件 979 2012-04-13 01:10 RSA.C
文件 7720 2012-04-12 20:58 SHA1.C
文件 7633 2012-04-12 20:55 SHA256.C
文件 2055 2012-04-12 21:55 TEA.C
文件 13233 2012-04-12 21:42 AES.c
文件 12757 2012-04-12 21:37 DES.C
----------- --------- ---------- ----- ----
60870 8
相关资源
- 3des加密算法C语言实现
- DES加密算法C语言实现
- C语言实现的DES对称加密算法
- BlowFish加密算法
- VC++实现RSA加密算法
- C++实现AES、DES加密算法含MFC界面
- 3DES加密算法C++实现
- DES/3DES算法C语言实现
- DES和3DES加密算法,C语言,适用于单片
- 各种加密算法C语言版
- SM4(ECB、CBC、CTR、CFB、OFB)加密算法
- stm32L系列F系列 加密库Cryptographic lib
- VC++ AES加密算法实现与范例的源代码
- 3DES加密算法 C++实现
- RSA加密算法用MFC实现
- ECDH加密算法 c语言版
- LZ77算法 C++实现
- DES加密算法 MFC
- aes加密算法源码
- RSA加密算法
- C++C#互通DES加密算法
- RSA加密算法C语言实现
- DES加密算法C语言版源代码
- AES加密算法C++语言实现
- 实验3 C语言实现RC4加密算法报告
- sha256-512加密算法
- RSA加密算法c语言
- DES加密算法MFC实现
- 椭圆曲线加密算法实现
- MD4加密算法源码
评论
共有 条评论