青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-23  評論-73  文章-3  trackbacks-0
/*-------------------------------------

SetKey函數提供設置加密長度還有密鑰功能
Encrypt函數實現文件加密
Decrypt函數實現文件解密


-------------------------------------*/


 


#include <stdio.h>
#include <stdlib.h>
#include <ntifs.h>
#include <assert.h>


 


// 這些函數是外界需要調用的


 


//AES初始化
void AES_Constructor(void);


void AES_Destructor(void);


 


//設置AES密鑰
BOOLEAN SetKey(const unsigned char *key, int keylen);



//AES加密函數
BOOLEAN Encrypt(const unsigned char *in, int inlen,
        unsigned char *out, int *outlen);



//AES解密函數
BOOLEAN Decrypt(const unsigned char *in, int inlen,
        unsigned char *out, int *outlen);


 


void Clear();


 


typedef unsigned char byte;
typedef unsigned long word;
typedef byte (State)[4][4];


void  Cipher(byte *in, byte *out);


void AddRoundKey(State state, word *w, int wstart);


void SubBytes(State state);


void ShiftRows(State state);


void MixColumns(State state);


void InvSubBytes(State state);


void InvShiftRows(State state);


void InvMixColumns(State state);


 


__inline word SubWord(word in);
__inline word RotWord(word in);


 


void InvCipher(byte *in, byte *out);


void KeyExpansion(byte *key, int keylen /* 4 * Nk */);


void EqKeyExpansion(byte *key, int keylen /* 4 * Nk */);


void EqInvCipher(byte *in, byte *out);


void  SetDecryptOption( BOOLEAN bEquivalent);


 


const byte m_Mul_02[] =
{
 0x1b,0x19,0x1f,0x1d,0x13,0x11,0x17,0x15,0x0b,0x09,0x0f,0x0d,0x03,0x01,0x07,0x05,
  0x3b,0x39,0x3f,0x3d,0x33,0x31,0x37,0x35,0x2b,0x29,0x2f,0x2d,0x23,0x21,0x27,0x25,
  0x5b,0x59,0x5f,0x5d,0x53,0x51,0x57,0x55,0x4b,0x49,0x4f,0x4d,0x43,0x41,0x47,0x45,
  0x7b,0x79,0x7f,0x7d,0x73,0x71,0x77,0x75,0x6b,0x69,0x6f,0x6d,0x63,0x61,0x67,0x65,
  0x9b,0x99,0x9f,0x9d,0x93,0x91,0x97,0x95,0x8b,0x89,0x8f,0x8d,0x83,0x81,0x87,0x85,
  0xbb,0xb9,0xbf,0xbd,0xb3,0xb1,0xb7,0xb5,0xab,0xa9,0xaf,0xad,0xa3,0xa1,0xa7,0xa5,
  0xdb,0xd9,0xdf,0xdd,0xd3,0xd1,0xd7,0xd5,0xcb,0xc9,0xcf,0xcd,0xc3,0xc1,0xc7,0xc5,
  0xfb,0xf9,0xff,0xfd,0xf3,0xf1,0xf7,0xf5,0xeb,0xe9,0xef,0xed,0xe3,0xe1,0xe7,0xe5,
  0x00,0x02,0x04,0x06,0x08,0x0a,0x0c,0x0e,0x10,0x12,0x14,0x16,0x18,0x1a,0x1c,0x1e,
  0x20,0x22,0x24,0x26,0x28,0x2a,0x2c,0x2e,0x30,0x32,0x34,0x36,0x38,0x3a,0x3c,0x3e,
  0x40,0x42,0x44,0x46,0x48,0x4a,0x4c,0x4e,0x50,0x52,0x54,0x56,0x58,0x5a,0x5c,0x5e,
  0x60,0x62,0x64,0x66,0x68,0x6a,0x6c,0x6e,0x70,0x72,0x74,0x76,0x78,0x7a,0x7c,0x7e,
  0x80,0x82,0x84,0x86,0x88,0x8a,0x8c,0x8e,0x90,0x92,0x94,0x96,0x98,0x9a,0x9c,0x9e,
  0xa0,0xa2,0xa4,0xa6,0xa8,0xaa,0xac,0xae,0xb0,0xb2,0xb4,0xb6,0xb8,0xba,0xbc,0xbe,
  0xc0,0xc2,0xc4,0xc6,0xc8,0xca,0xcc,0xce,0xd0,0xd2,0xd4,0xd6,0xd8,0xda,0xdc,0xde,
  0xe0,0xe2,0xe4,0xe6,0xe8,0xea,0xec,0xee,0xf0,0xf2,0xf4,0xf6,0xf8,0xfa,0xfc,0xfe,
};
const byte m_Mul_03[] =
{
 0x1b,0x18,0x1d,0x1e,0x17,0x14,0x11,0x12,0x03,0x00,0x05,0x06,0x0f,0x0c,0x09,0x0a,
  0x2b,0x28,0x2d,0x2e,0x27,0x24,0x21,0x22,0x33,0x30,0x35,0x36,0x3f,0x3c,0x39,0x3a,
  0x7b,0x78,0x7d,0x7e,0x77,0x74,0x71,0x72,0x63,0x60,0x65,0x66,0x6f,0x6c,0x69,0x6a,
  0x4b,0x48,0x4d,0x4e,0x47,0x44,0x41,0x42,0x53,0x50,0x55,0x56,0x5f,0x5c,0x59,0x5a,
  0xdb,0xd8,0xdd,0xde,0xd7,0xd4,0xd1,0xd2,0xc3,0xc0,0xc5,0xc6,0xcf,0xcc,0xc9,0xca,
  0xeb,0xe8,0xed,0xee,0xe7,0xe4,0xe1,0xe2,0xf3,0xf0,0xf5,0xf6,0xff,0xfc,0xf9,0xfa,
  0xbb,0xb8,0xbd,0xbe,0xb7,0xb4,0xb1,0xb2,0xa3,0xa0,0xa5,0xa6,0xaf,0xac,0xa9,0xaa,
  0x8b,0x88,0x8d,0x8e,0x87,0x84,0x81,0x82,0x93,0x90,0x95,0x96,0x9f,0x9c,0x99,0x9a,
  0x80,0x83,0x86,0x85,0x8c,0x8f,0x8a,0x89,0x98,0x9b,0x9e,0x9d,0x94,0x97,0x92,0x91,
  0xb0,0xb3,0xb6,0xb5,0xbc,0xbf,0xba,0xb9,0xa8,0xab,0xae,0xad,0xa4,0xa7,0xa2,0xa1,
  0xe0,0xe3,0xe6,0xe5,0xec,0xef,0xea,0xe9,0xf8,0xfb,0xfe,0xfd,0xf4,0xf7,0xf2,0xf1,
  0xd0,0xd3,0xd6,0xd5,0xdc,0xdf,0xda,0xd9,0xc8,0xcb,0xce,0xcd,0xc4,0xc7,0xc2,0xc1,
  0x40,0x43,0x46,0x45,0x4c,0x4f,0x4a,0x49,0x58,0x5b,0x5e,0x5d,0x54,0x57,0x52,0x51,
  0x70,0x73,0x76,0x75,0x7c,0x7f,0x7a,0x79,0x68,0x6b,0x6e,0x6d,0x64,0x67,0x62,0x61,
  0x20,0x23,0x26,0x25,0x2c,0x2f,0x2a,0x29,0x38,0x3b,0x3e,0x3d,0x34,0x37,0x32,0x31,
  0x10,0x13,0x16,0x15,0x1c,0x1f,0x1a,0x19,0x08,0x0b,0x0e,0x0d,0x04,0x07,0x02,0x01,
};
const byte m_Mul_04[] =
{
 0x2d,0x29,0x25,0x21,0x3d,0x39,0x35,0x31,0x0d,0x09,0x05,0x01,0x1d,0x19,0x15,0x11,
  0x6d,0x69,0x65,0x61,0x7d,0x79,0x75,0x71,0x4d,0x49,0x45,0x41,0x5d,0x59,0x55,0x51,
  0xad,0xa9,0xa5,0xa1,0xbd,0xb9,0xb5,0xb1,0x8d,0x89,0x85,0x81,0x9d,0x99,0x95,0x91,
  0xed,0xe9,0xe5,0xe1,0xfd,0xf9,0xf5,0xf1,0xcd,0xc9,0xc5,0xc1,0xdd,0xd9,0xd5,0xd1,
  0x36,0x32,0x3e,0x3a,0x26,0x22,0x2e,0x2a,0x16,0x12,0x1e,0x1a,0x06,0x02,0x0e,0x0a,
  0x76,0x72,0x7e,0x7a,0x66,0x62,0x6e,0x6a,0x56,0x52,0x5e,0x5a,0x46,0x42,0x4e,0x4a,
  0xb6,0xb2,0xbe,0xba,0xa6,0xa2,0xae,0xaa,0x96,0x92,0x9e,0x9a,0x86,0x82,0x8e,0x8a,
  0xf6,0xf2,0xfe,0xfa,0xe6,0xe2,0xee,0xea,0xd6,0xd2,0xde,0xda,0xc6,0xc2,0xce,0xca,
  0x1b,0x1f,0x13,0x17,0x0b,0x0f,0x03,0x07,0x3b,0x3f,0x33,0x37,0x2b,0x2f,0x23,0x27,
  0x5b,0x5f,0x53,0x57,0x4b,0x4f,0x43,0x47,0x7b,0x7f,0x73,0x77,0x6b,0x6f,0x63,0x67,
  0x9b,0x9f,0x93,0x97,0x8b,0x8f,0x83,0x87,0xbb,0xbf,0xb3,0xb7,0xab,0xaf,0xa3,0xa7,
  0xdb,0xdf,0xd3,0xd7,0xcb,0xcf,0xc3,0xc7,0xfb,0xff,0xf3,0xf7,0xeb,0xef,0xe3,0xe7,
  0x00,0x04,0x08,0x0c,0x10,0x14,0x18,0x1c,0x20,0x24,0x28,0x2c,0x30,0x34,0x38,0x3c,
  0x40,0x44,0x48,0x4c,0x50,0x54,0x58,0x5c,0x60,0x64,0x68,0x6c,0x70,0x74,0x78,0x7c,
  0x80,0x84,0x88,0x8c,0x90,0x94,0x98,0x9c,0xa0,0xa4,0xa8,0xac,0xb0,0xb4,0xb8,0xbc,
  0xc0,0xc4,0xc8,0xcc,0xd0,0xd4,0xd8,0xdc,0xe0,0xe4,0xe8,0xec,0xf0,0xf4,0xf8,0xfc,
};
const byte m_Mul_08[] =
{
 0x41,0x49,0x51,0x59,0x61,0x69,0x71,0x79,0x01,0x09,0x11,0x19,0x21,0x29,0x31,0x39,
  0xc1,0xc9,0xd1,0xd9,0xe1,0xe9,0xf1,0xf9,0x81,0x89,0x91,0x99,0xa1,0xa9,0xb1,0xb9,
  0x5a,0x52,0x4a,0x42,0x7a,0x72,0x6a,0x62,0x1a,0x12,0x0a,0x02,0x3a,0x32,0x2a,0x22,
  0xda,0xd2,0xca,0xc2,0xfa,0xf2,0xea,0xe2,0x9a,0x92,0x8a,0x82,0xba,0xb2,0xaa,0xa2,
  0x77,0x7f,0x67,0x6f,0x57,0x5f,0x47,0x4f,0x37,0x3f,0x27,0x2f,0x17,0x1f,0x07,0x0f,
  0xf7,0xff,0xe7,0xef,0xd7,0xdf,0xc7,0xcf,0xb7,0xbf,0xa7,0xaf,0x97,0x9f,0x87,0x8f,
  0x6c,0x64,0x7c,0x74,0x4c,0x44,0x5c,0x54,0x2c,0x24,0x3c,0x34,0x0c,0x04,0x1c,0x14,
  0xec,0xe4,0xfc,0xf4,0xcc,0xc4,0xdc,0xd4,0xac,0xa4,0xbc,0xb4,0x8c,0x84,0x9c,0x94,
  0x2d,0x25,0x3d,0x35,0x0d,0x05,0x1d,0x15,0x6d,0x65,0x7d,0x75,0x4d,0x45,0x5d,0x55,
  0xad,0xa5,0xbd,0xb5,0x8d,0x85,0x9d,0x95,0xed,0xe5,0xfd,0xf5,0xcd,0xc5,0xdd,0xd5,
  0x36,0x3e,0x26,0x2e,0x16,0x1e,0x06,0x0e,0x76,0x7e,0x66,0x6e,0x56,0x5e,0x46,0x4e,
  0xb6,0xbe,0xa6,0xae,0x96,0x9e,0x86,0x8e,0xf6,0xfe,0xe6,0xee,0xd6,0xde,0xc6,0xce,
  0x1b,0x13,0x0b,0x03,0x3b,0x33,0x2b,0x23,0x5b,0x53,0x4b,0x43,0x7b,0x73,0x6b,0x63,
  0x9b,0x93,0x8b,0x83,0xbb,0xb3,0xab,0xa3,0xdb,0xd3,0xcb,0xc3,0xfb,0xf3,0xeb,0xe3,
  0x00,0x08,0x10,0x18,0x20,0x28,0x30,0x38,0x40,0x48,0x50,0x58,0x60,0x68,0x70,0x78,
  0x80,0x88,0x90,0x98,0xa0,0xa8,0xb0,0xb8,0xc0,0xc8,0xd0,0xd8,0xe0,0xe8,0xf0,0xf8,
};
const byte m_Mul_09[] =
{
 0x41,0x48,0x53,0x5a,0x65,0x6c,0x77,0x7e,0x09,0x00,0x1b,0x12,0x2d,0x24,0x3f,0x36,
  0xd1,0xd8,0xc3,0xca,0xf5,0xfc,0xe7,0xee,0x99,0x90,0x8b,0x82,0xbd,0xb4,0xaf,0xa6,
  0x7a,0x73,0x68,0x61,0x5e,0x57,0x4c,0x45,0x32,0x3b,0x20,0x29,0x16,0x1f,0x04,0x0d,
  0xea,0xe3,0xf8,0xf1,0xce,0xc7,0xdc,0xd5,0xa2,0xab,0xb0,0xb9,0x86,0x8f,0x94,0x9d,
  0x37,0x3e,0x25,0x2c,0x13,0x1a,0x01,0x08,0x7f,0x76,0x6d,0x64,0x5b,0x52,0x49,0x40,
  0xa7,0xae,0xb5,0xbc,0x83,0x8a,0x91,0x98,0xef,0xe6,0xfd,0xf4,0xcb,0xc2,0xd9,0xd0,
  0x0c,0x05,0x1e,0x17,0x28,0x21,0x3a,0x33,0x44,0x4d,0x56,0x5f,0x60,0x69,0x72,0x7b,
  0x9c,0x95,0x8e,0x87,0xb8,0xb1,0xaa,0xa3,0xd4,0xdd,0xc6,0xcf,0xf0,0xf9,0xe2,0xeb,
  0xad,0xa4,0xbf,0xb6,0x89,0x80,0x9b,0x92,0xe5,0xec,0xf7,0xfe,0xc1,0xc8,0xd3,0xda,
  0x3d,0x34,0x2f,0x26,0x19,0x10,0x0b,0x02,0x75,0x7c,0x67,0x6e,0x51,0x58,0x43,0x4a,
  0x96,0x9f,0x84,0x8d,0xb2,0xbb,0xa0,0xa9,0xde,0xd7,0xcc,0xc5,0xfa,0xf3,0xe8,0xe1,
  0x06,0x0f,0x14,0x1d,0x22,0x2b,0x30,0x39,0x4e,0x47,0x5c,0x55,0x6a,0x63,0x78,0x71,
  0xdb,0xd2,0xc9,0xc0,0xff,0xf6,0xed,0xe4,0x93,0x9a,0x81,0x88,0xb7,0xbe,0xa5,0xac,
  0x4b,0x42,0x59,0x50,0x6f,0x66,0x7d,0x74,0x03,0x0a,0x11,0x18,0x27,0x2e,0x35,0x3c,
  0xe0,0xe9,0xf2,0xfb,0xc4,0xcd,0xd6,0xdf,0xa8,0xa1,0xba,0xb3,0x8c,0x85,0x9e,0x97,
  0x70,0x79,0x62,0x6b,0x54,0x5d,0x46,0x4f,0x38,0x31,0x2a,0x23,0x1c,0x15,0x0e,0x07,
};
const byte m_Mul_0b[] =
{
 0x5a,0x51,0x4c,0x47,0x76,0x7d,0x60,0x6b,0x02,0x09,0x14,0x1f,0x2e,0x25,0x38,0x33,
  0xea,0xe1,0xfc,0xf7,0xc6,0xcd,0xd0,0xdb,0xb2,0xb9,0xa4,0xaf,0x9e,0x95,0x88,0x83,
  0x21,0x2a,0x37,0x3c,0x0d,0x06,0x1b,0x10,0x79,0x72,0x6f,0x64,0x55,0x5e,0x43,0x48,
  0x91,0x9a,0x87,0x8c,0xbd,0xb6,0xab,0xa0,0xc9,0xc2,0xdf,0xd4,0xe5,0xee,0xf3,0xf8,
  0xac,0xa7,0xba,0xb1,0x80,0x8b,0x96,0x9d,0xf4,0xff,0xe2,0xe9,0xd8,0xd3,0xce,0xc5,
  0x1c,0x17,0x0a,0x01,0x30,0x3b,0x26,0x2d,0x44,0x4f,0x52,0x59,0x68,0x63,0x7e,0x75,
  0xd7,0xdc,0xc1,0xca,0xfb,0xf0,0xed,0xe6,0x8f,0x84,0x99,0x92,0xa3,0xa8,0xb5,0xbe,
  0x67,0x6c,0x71,0x7a,0x4b,0x40,0x5d,0x56,0x3f,0x34,0x29,0x22,0x13,0x18,0x05,0x0e,
  0xad,0xa6,0xbb,0xb0,0x81,0x8a,0x97,0x9c,0xf5,0xfe,0xe3,0xe8,0xd9,0xd2,0xcf,0xc4,
  0x1d,0x16,0x0b,0x00,0x31,0x3a,0x27,0x2c,0x45,0x4e,0x53,0x58,0x69,0x62,0x7f,0x74,
  0xd6,0xdd,0xc0,0xcb,0xfa,0xf1,0xec,0xe7,0x8e,0x85,0x98,0x93,0xa2,0xa9,0xb4,0xbf,
  0x66,0x6d,0x70,0x7b,0x4a,0x41,0x5c,0x57,0x3e,0x35,0x28,0x23,0x12,0x19,0x04,0x0f,
  0x5b,0x50,0x4d,0x46,0x77,0x7c,0x61,0x6a,0x03,0x08,0x15,0x1e,0x2f,0x24,0x39,0x32,
  0xeb,0xe0,0xfd,0xf6,0xc7,0xcc,0xd1,0xda,0xb3,0xb8,0xa5,0xae,0x9f,0x94,0x89,0x82,
  0x20,0x2b,0x36,0x3d,0x0c,0x07,0x1a,0x11,0x78,0x73,0x6e,0x65,0x54,0x5f,0x42,0x49,
  0x90,0x9b,0x86,0x8d,0xbc,0xb7,0xaa,0xa1,0xc8,0xc3,0xde,0xd5,0xe4,0xef,0xf2,0xf9,
};
const byte m_Mul_0d[] =
{
 0x6c,0x61,0x76,0x7b,0x58,0x55,0x42,0x4f,0x04,0x09,0x1e,0x13,0x30,0x3d,0x2a,0x27,
  0xbc,0xb1,0xa6,0xab,0x88,0x85,0x92,0x9f,0xd4,0xd9,0xce,0xc3,0xe0,0xed,0xfa,0xf7,
  0xd7,0xda,0xcd,0xc0,0xe3,0xee,0xf9,0xf4,0xbf,0xb2,0xa5,0xa8,0x8b,0x86,0x91,0x9c,
  0x07,0x0a,0x1d,0x10,0x33,0x3e,0x29,0x24,0x6f,0x62,0x75,0x78,0x5b,0x56,0x41,0x4c,
  0x01,0x0c,0x1b,0x16,0x35,0x38,0x2f,0x22,0x69,0x64,0x73,0x7e,0x5d,0x50,0x47,0x4a,
  0xd1,0xdc,0xcb,0xc6,0xe5,0xe8,0xff,0xf2,0xb9,0xb4,0xa3,0xae,0x8d,0x80,0x97,0x9a,
  0xba,0xb7,0xa0,0xad,0x8e,0x83,0x94,0x99,0xd2,0xdf,0xc8,0xc5,0xe6,0xeb,0xfc,0xf1,
  0x6a,0x67,0x70,0x7d,0x5e,0x53,0x44,0x49,0x02,0x0f,0x18,0x15,0x36,0x3b,0x2c,0x21,
  0xb6,0xbb,0xac,0xa1,0x82,0x8f,0x98,0x95,0xde,0xd3,0xc4,0xc9,0xea,0xe7,0xf0,0xfd,
  0x66,0x6b,0x7c,0x71,0x52,0x5f,0x48,0x45,0x0e,0x03,0x14,0x19,0x3a,0x37,0x20,0x2d,
  0x0d,0x00,0x17,0x1a,0x39,0x34,0x23,0x2e,0x65,0x68,0x7f,0x72,0x51,0x5c,0x4b,0x46,
  0xdd,0xd0,0xc7,0xca,0xe9,0xe4,0xf3,0xfe,0xb5,0xb8,0xaf,0xa2,0x81,0x8c,0x9b,0x96,
  0xdb,0xd6,0xc1,0xcc,0xef,0xe2,0xf5,0xf8,0xb3,0xbe,0xa9,0xa4,0x87,0x8a,0x9d,0x90,
  0x0b,0x06,0x11,0x1c,0x3f,0x32,0x25,0x28,0x63,0x6e,0x79,0x74,0x57,0x5a,0x4d,0x40,
  0x60,0x6d,0x7a,0x77,0x54,0x59,0x4e,0x43,0x08,0x05,0x12,0x1f,0x3c,0x31,0x26,0x2b,
  0xb0,0xbd,0xaa,0xa7,0x84,0x89,0x9e,0x93,0xd8,0xd5,0xc2,0xcf,0xec,0xe1,0xf6,0xfb,
};
const byte m_Mul_0e[] =
{
 0x77,0x79,0x6b,0x65,0x4f,0x41,0x53,0x5d,0x07,0x09,0x1b,0x15,0x3f,0x31,0x23,0x2d,
  0x97,0x99,0x8b,0x85,0xaf,0xa1,0xb3,0xbd,0xe7,0xe9,0xfb,0xf5,0xdf,0xd1,0xc3,0xcd,
  0xac,0xa2,0xb0,0xbe,0x94,0x9a,0x88,0x86,0xdc,0xd2,0xc0,0xce,0xe4,0xea,0xf8,0xf6,
  0x4c,0x42,0x50,0x5e,0x74,0x7a,0x68,0x66,0x3c,0x32,0x20,0x2e,0x04,0x0a,0x18,0x16,
  0xda,0xd4,0xc6,0xc8,0xe2,0xec,0xfe,0xf0,0xaa,0xa4,0xb6,0xb8,0x92,0x9c,0x8e,0x80,
  0x3a,0x34,0x26,0x28,0x02,0x0c,0x1e,0x10,0x4a,0x44,0x56,0x58,0x72,0x7c,0x6e,0x60,
  0x01,0x0f,0x1d,0x13,0x39,0x37,0x25,0x2b,0x71,0x7f,0x6d,0x63,0x49,0x47,0x55,0x5b,
  0xe1,0xef,0xfd,0xf3,0xd9,0xd7,0xc5,0xcb,0x91,0x9f,0x8d,0x83,0xa9,0xa7,0xb5,0xbb,
  0x36,0x38,0x2a,0x24,0x0e,0x00,0x12,0x1c,0x46,0x48,0x5a,0x54,0x7e,0x70,0x62,0x6c,
  0xd6,0xd8,0xca,0xc4,0xee,0xe0,0xf2,0xfc,0xa6,0xa8,0xba,0xb4,0x9e,0x90,0x82,0x8c,
  0xed,0xe3,0xf1,0xff,0xd5,0xdb,0xc9,0xc7,0x9d,0x93,0x81,0x8f,0xa5,0xab,0xb9,0xb7,
  0x0d,0x03,0x11,0x1f,0x35,0x3b,0x29,0x27,0x7d,0x73,0x61,0x6f,0x45,0x4b,0x59,0x57,
  0x9b,0x95,0x87,0x89,0xa3,0xad,0xbf,0xb1,0xeb,0xe5,0xf7,0xf9,0xd3,0xdd,0xcf,0xc1,
  0x7b,0x75,0x67,0x69,0x43,0x4d,0x5f,0x51,0x0b,0x05,0x17,0x19,0x33,0x3d,0x2f,0x21,
  0x40,0x4e,0x5c,0x52,0x78,0x76,0x64,0x6a,0x30,0x3e,0x2c,0x22,0x08,0x06,0x14,0x1a,
  0xa0,0xae,0xbc,0xb2,0x98,0x96,0x84,0x8a,0xd0,0xde,0xcc,0xc2,0xe8,0xe6,0xf4,0xfa,
};



const byte m_Sbox[] =
{
 0x63,0x7c,0x77,0x7b,0xf2,0x6b,0x6f,0xc5,0x30,0x01,0x67,0x2b,0xfe,0xd7,0xab,0x76,
  0xca,0x82,0xc9,0x7d,0xfa,0x59,0x47,0xf0,0xad,0xd4,0xa2,0xaf,0x9c,0xa4,0x72,0xc0,
  0xb7,0xfd,0x93,0x26,0x36,0x3f,0xf7,0xcc,0x34,0xa5,0xe5,0xf1,0x71,0xd8,0x31,0x15,
  0x04,0xc7,0x23,0xc3,0x18,0x96,0x05,0x9a,0x07,0x12,0x80,0xe2,0xeb,0x27,0xb2,0x75,
  0x09,0x83,0x2c,0x1a,0x1b,0x6e,0x5a,0xa0,0x52,0x3b,0xd6,0xb3,0x29,0xe3,0x2f,0x84,
  0x53,0xd1,0x00,0xed,0x20,0xfc,0xb1,0x5b,0x6a,0xcb,0xbe,0x39,0x4a,0x4c,0x58,0xcf,
  0xd0,0xef,0xaa,0xfb,0x43,0x4d,0x33,0x85,0x45,0xf9,0x02,0x7f,0x50,0x3c,0x9f,0xa8,
  0x51,0xa3,0x40,0x8f,0x92,0x9d,0x38,0xf5,0xbc,0xb6,0xda,0x21,0x10,0xff,0xf3,0xd2,
  0xcd,0x0c,0x13,0xec,0x5f,0x97,0x44,0x17,0xc4,0xa7,0x7e,0x3d,0x64,0x5d,0x19,0x73,
  0x60,0x81,0x4f,0xdc,0x22,0x2a,0x90,0x88,0x46,0xee,0xb8,0x14,0xde,0x5e,0x0b,0xdb,
  0xe0,0x32,0x3a,0x0a,0x49,0x06,0x24,0x5c,0xc2,0xd3,0xac,0x62,0x91,0x95,0xe4,0x79,
  0xe7,0xc8,0x37,0x6d,0x8d,0xd5,0x4e,0xa9,0x6c,0x56,0xf4,0xea,0x65,0x7a,0xae,0x08,
  0xba,0x78,0x25,0x2e,0x1c,0xa6,0xb4,0xc6,0xe8,0xdd,0x74,0x1f,0x4b,0xbd,0x8b,0x8a,
  0x70,0x3e,0xb5,0x66,0x48,0x03,0xf6,0x0e,0x61,0x35,0x57,0xb9,0x86,0xc1,0x1d,0x9e,
  0xe1,0xf8,0x98,0x11,0x69,0xd9,0x8e,0x94,0x9b,0x1e,0x87,0xe9,0xce,0x55,0x28,0xdf,
  0x8c,0xa1,0x89,0x0d,0xbf,0xe6,0x42,0x68,0x41,0x99,0x2d,0x0f,0xb0,0x54,0xbb,0x16,
};


const byte m_InvSbox[] =
{
 0x52,0x09,0x6a,0xd5,0x30,0x36,0xa5,0x38,0xbf,0x40,0xa3,0x9e,0x81,0xf3,0xd7,0xfb,
  0x7c,0xe3,0x39,0x82,0x9b,0x2f,0xff,0x87,0x34,0x8e,0x43,0x44,0xc4,0xde,0xe9,0xcb,
  0x54,0x7b,0x94,0x32,0xa6,0xc2,0x23,0x3d,0xee,0x4c,0x95,0x0b,0x42,0xfa,0xc3,0x4e,
  0x08,0x2e,0xa1,0x66,0x28,0xd9,0x24,0xb2,0x76,0x5b,0xa2,0x49,0x6d,0x8b,0xd1,0x25,
  0x72,0xf8,0xf6,0x64,0x86,0x68,0x98,0x16,0xd4,0xa4,0x5c,0xcc,0x5d,0x65,0xb6,0x92,
  0x6c,0x70,0x48,0x50,0xfd,0xed,0xb9,0xda,0x5e,0x15,0x46,0x57,0xa7,0x8d,0x9d,0x84,
  0x90,0xd8,0xab,0x00,0x8c,0xbc,0xd3,0x0a,0xf7,0xe4,0x58,0x05,0xb8,0xb3,0x45,0x06,
  0xd0,0x2c,0x1e,0x8f,0xca,0x3f,0x0f,0x02,0xc1,0xaf,0xbd,0x03,0x01,0x13,0x8a,0x6b,
  0x3a,0x91,0x11,0x41,0x4f,0x67,0xdc,0xea,0x97,0xf2,0xcf,0xce,0xf0,0xb4,0xe6,0x73,
  0x96,0xac,0x74,0x22,0xe7,0xad,0x35,0x85,0xe2,0xf9,0x37,0xe8,0x1c,0x75,0xdf,0x6e,
  0x47,0xf1,0x1a,0x71,0x1d,0x29,0xc5,0x89,0x6f,0xb7,0x62,0x0e,0xaa,0x18,0xbe,0x1b,
  0xfc,0x56,0x3e,0x4b,0xc6,0xd2,0x79,0x20,0x9a,0xdb,0xc0,0xfe,0x78,0xcd,0x5a,0xf4,
  0x1f,0xdd,0xa8,0x33,0x88,0x07,0xc7,0x31,0xb1,0x12,0x10,0x59,0x27,0x80,0xec,0x5f,
  0x60,0x51,0x7f,0xa9,0x19,0xb5,0x4a,0x0d,0x2d,0xe5,0x7a,0x9f,0x93,0xc9,0x9c,0xef,
  0xa0,0xe0,0x3b,0x4d,0xae,0x2a,0xf5,0xb0,0xc8,0xeb,0xbb,0x3c,0x83,0x53,0x99,0x61,
  0x17,0x2b,0x04,0x7e,0xba,0x77,0xd6,0x26,0xe1,0x69,0x14,0x63,0x55,0x21,0x0c,0x7d,
};


const static word m_Rcon[11] =
{
 0xffffffff,
  0x01000000, 0x02000000, 0x04000000, 0x08000000, 0x10000000,
  0x20000000, 0x40000000, 0x80000000, 0x1b000000, 0x36000000,


};


int m_Nk;
int m_Nr;
// Key Expansion
word m_w[60]; // Max Nb * (Nr + 1)
// Eq Key Expansion
word m_dw[60];


BOOLEAN m_bEq;



VOID AES_Constructor(VOID)
{
 m_Nk = 6;
 m_Nr = 12;
 m_bEq = FALSE;


 memset(m_w, 0, sizeof(m_w));
 memset(m_dw, 0, sizeof(m_dw));
}


VOID AES_Destructor(VOID)
{
 
}



void Cipher(byte *in, byte *out)
{
 int r;
 int c;
 int round;


 State state;
 
 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   state[r][c] = in[r + 4 * c];
  }
 }


 AddRoundKey(state, m_w, 0);


 for(round = 1; round < m_Nr; round++)
 {
  SubBytes(state);
  ShiftRows(state);
  MixColumns(state);
  AddRoundKey(state, m_w, round * 4);
 }


 SubBytes(state);
 ShiftRows(state);
 AddRoundKey(state, m_w, m_Nr * 4);


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   out[r + 4 * c] = state[r][c];
  }
 }
}


void AddRoundKey(State state, word *w, int wstart)
{
 int c ;


 for(c = 0; c < 4; c++)
 {
  state[0][c] ^= w[wstart + c] >> 24;
  state[1][c] ^= (w[wstart + c] & 0xff0000) >> 16;
  state[2][c] ^= (w[wstart + c] & 0xff00) >> 8;
  state[3][c] ^= w[wstart + c] & 0xff;
 }
}



void SubBytes(State state)
{
 int r ;
 int c;


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   state[r][c] = m_Sbox[state[r][c]];
  }
 }


}


void ShiftRows(State state)
{
 byte tmp[3];
 int c ;
 int r ;
 int i ;
 int k;


 for( r = 1; r < 4; r++)
 {
  for(i = 0; i < r; i++)
  {
   tmp = state[r];
  }


  for(c = r; c < 4; c++)
  {
   state[r][c - r] = state[r][c];
  }


  for(i = 0; i < r; i++)
  {
   state[r][i + 4 - r] = tmp;
  }


 }


}


void MixColumns(State state)
{
 byte tmp[4];


 int c ;


 for(c = 0; c < 4; c++)
 {
  tmp[0] = m_Mul_02[state[0][c]] ^ m_Mul_03[state[1][c]] ^
   state[2][c] ^ state[3][c];
  tmp[1] = state[0][c] ^ m_Mul_02[state[1][c]] ^
   m_Mul_03[state[2][c]] ^ state[3][c];
  tmp[2] = state[0][c] ^ state[1][c] ^
   m_Mul_02[state[2][c]] ^ m_Mul_03[state[3][c]];
  tmp[3] = m_Mul_03[state[0][c]] ^ state[1][c] ^
   state[2][c] ^ m_Mul_02[state[3][c]];
  state[0][c] = tmp[0];
  state[1][c] = tmp[1];
  state[2][c] = tmp[2];
  state[3][c] = tmp[3];
 }


}


void InvSubBytes(State state)
{
 int r ;
 int c ;


 for(r= 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   state[r][c] = m_InvSbox[state[r][c]];
  }
 }
}



void InvShiftRows(State state)
{
 byte tmp[3];


 int r;
 int i ;
 int c ;


 for(r = 1; r < 4; r++)
 {
  for(i = 0; i < r; i++)
  {
   tmp = state[r][4 - r + i];
  }
  for(c = 4 - r - 1; c >= 0; c--)
  {
   state[r][c + r] = state[r][c];
  }
  for(i = 0; i < r; i++)
  {
   state[r] = tmp;
  }
 }
}



void InvMixColumns(State state)
{
 byte tmp[4];
 int c ;


 for(c = 0; c < 4; c++)
 {
  tmp[0] = m_Mul_0e[state[0][c]] ^ m_Mul_0b[state[1][c]] ^
   m_Mul_0d[state[2][c]] ^ m_Mul_09[state[3][c]];
  tmp[1] = m_Mul_09[state[0][c]] ^ m_Mul_0e[state[1][c]] ^
   m_Mul_0b[state[2][c]] ^ m_Mul_0d[state[3][c]];
  tmp[2] = m_Mul_0d[state[0][c]] ^ m_Mul_09[state[1][c]] ^
   m_Mul_0e[state[2][c]] ^ m_Mul_0b[state[3][c]];
  tmp[3] = m_Mul_0b[state[0][c]] ^ m_Mul_0d[state[1][c]] ^
   m_Mul_09[state[2][c]] ^ m_Mul_0e[state[3][c]];
  state[0][c] = tmp[0];
  state[1][c] = tmp[1];
  state[2][c] = tmp[2];
  state[3][c] = tmp[3];
 }
}


 


__inline word SubWord(word in)
{
 return m_Sbox[in >> 24] << 24 | m_Sbox[(in & 0xff0000) >> 16] << 16 |
  m_Sbox[(in & 0xff00) >> 8] << 8 | m_Sbox[in & 0xff];
}


__inline word RotWord(word in)
{
 return (in << 8) | (in >> 24);
}


void KeyExpansion(byte *key, int keylen /* 4 * Nk */)
{


 word temp;


 int i = 0;


 assert(keylen == 4 * m_Nk);


 while (i < m_Nk)
 {
  m_w[i++] = key[4 * i] << 24 | key[4 * i + 1] << 16 |
   key[4 * i + 2] << 8 | key[4 * i + 3];
 }


 i = m_Nk;


 while (i < 4 * (m_Nr + 1))
 {
  temp = m_w[i - 1];
  if(i % m_Nk == 0)
  {
   temp = SubWord(RotWord(temp)) ^ m_Rcon[i / m_Nk];
  }
  else if(m_Nk > 6 && i % m_Nk == 4)
  {
   temp = SubWord(temp);
  }
  m_w = m_w[i - m_Nk] ^ temp;
  i++;
 }
}



void InvCipher(byte *in, byte *out)
{
 State state;


 int r ;
 int c ;
 int round ;


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   state[r][c] = in[r + 4 * c];
  }
 }


 AddRoundKey(state, m_w, m_Nr * 4);


 for(round = m_Nr - 1; round > 0; round--)
 {
  InvShiftRows(state);
  InvSubBytes(state);
  AddRoundKey(state, m_w, round * 4);
  InvMixColumns(state);
 }


 InvShiftRows(state);
 InvSubBytes(state);
 AddRoundKey(state, m_w, 0);


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   out[r + 4 * c] = state[r][c];
  }
 }
}



void EqKeyExpansion(byte *key, int keylen /* 4 * Nk */)
{
 State s;
 byte *in;
 int r ;
 int c ;
 int i;
 int round ;


 KeyExpansion(key, keylen);


 for( i= 0; i < 4 * (m_Nr + 1); i++)
 {
  m_dw = m_w;
 }


 for(round = 1; round < m_Nr; round++)
 {
  in = (byte*)(m_dw + round * 4);
  for(r = 0; r < 4; r++)
  {
   for(c = 0; c < 4; c++)
   {
    s[r][c] = in[4 * c + 4 - r - 1];
   }
  }
  
  InvMixColumns(s);


  for(r = 0; r < 4; r++)
  {
   for(c = 0; c < 4; c++)
   {
    in[4 * c + 4 - r - 1] = s[r][c];
   }
  }
 }
}


void EqInvCipher(byte *in, byte *out)
{
 State state;
 int r;
 int c;
 int round;


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   state[r][c] = in[r + 4 * c];
  }
 }


 AddRoundKey(state, m_dw, m_Nr * 4);


 for(round = m_Nr - 1; round > 0; round--)
 {
  InvSubBytes(state);
  InvShiftRows(state);
  InvMixColumns(state);
  AddRoundKey(state, m_dw, round * 4);
 }


 InvSubBytes(state);
 InvShiftRows(state);
 AddRoundKey(state, m_dw, 0);


 for(r = 0; r < 4; r++)
 {
  for(c = 0; c < 4; c++)
  {
   out[r + 4 * c] = state[r][c];
  }
 }
}


void  SetDecryptOption( BOOLEAN bEquivalent)
{
 m_bEq = bEquivalent;
}



BOOLEAN SetKey(const unsigned char *key, int keylen)
{
 switch(keylen)
 {
 case 16:
  m_Nk = 4;
  m_Nr = 10;
  break;
 case 24:
  m_Nk = 6;
  m_Nr = 12;
  break;
 case 32:
  m_Nk = 8;
  m_Nr = 14;
  break;
 default:
  return FALSE;
 }


 if(m_bEq)
 {
  EqKeyExpansion((byte*)key, keylen);
 }
 else
 {
  KeyExpansion((byte*)key, keylen);
 }


 return TRUE;
}



BOOLEAN Encrypt(const unsigned char *in, int inlen,
        unsigned char *out, int *outlen)
{
 int tmp;
 int i;


 if(!in)
  return FALSE;


 if(inlen <= 0)
  return FALSE;


 tmp = inlen % (16) ? inlen + (16) - inlen % (16) : inlen;
 
 if(!out || *outlen < tmp)
 {
  *outlen = tmp;
  return FALSE;
 }


 *outlen = tmp;


 while(inlen >= 16)
 {
  Cipher((byte*)in, out);
  in += 16;
  out += 16;
  inlen -= 16;
 }


 if(inlen > 0)
 {
  byte pad[16];


  for(i = 0; i < inlen; i++)
  {
   pad = in;
  }


  for( i = inlen; i < 16; i++)
  {
   pad = 0;
  }


  Cipher(pad, out);
 }


 return TRUE;
}


BOOLEAN Decrypt(const unsigned char *in, int inlen,
        unsigned char *out, int *outlen)
{
 if(!in)
  return FALSE;


 if(inlen <= 0 || inlen % (16) != 0)
  return FALSE;


 if(!out || *outlen < inlen)
 {
  *outlen = inlen;
  return FALSE;
 }


 *outlen = inlen;


 if(m_bEq)
 {
  while(inlen >= 16)
  {
   EqInvCipher((byte*)in, out);
   in += 16;
   out += 16;
   inlen -= 16;
  }
 }
 else
 {
  while(inlen >= 16)
  {
   InvCipher((byte*)in, out);
   in += 16;
   out += 16;
   inlen -= 16;
  }
 }


 return TRUE;
}


 


void Clear()

 memset(m_w, 0, sizeof(m_w));
 memset(m_w, 0, sizeof(m_dw));
}

posted on 2008-04-19 13:02 ViskerWong 閱讀(1969) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一二三四社区欧美黄| 亚洲精品麻豆| 99热精品在线| 亚洲精品在线看| 夜夜嗨av色一区二区不卡| 亚洲免费观看高清完整版在线观看熊| 亚洲电影第三页| 亚洲精品资源| 欧美一区二区三区视频在线| 翔田千里一区二区| 久久久久九九视频| 欧美激情视频在线播放| 国产精品99久久久久久久女警| 亚洲一二三区精品| 久久午夜色播影院免费高清| 欧美日韩你懂的| 国产一区二区日韩精品| 亚洲日本中文| 欧美在线资源| 亚洲日本成人女熟在线观看| 亚洲伊人久久综合| 欧美1区2区视频| 国产精品久久久亚洲一区| 黄色成人在线免费| 亚洲深夜福利在线| 国产精品久久久91| 国产精品一级久久久| 国产欧美精品日韩精品| 亚洲国产精品尤物yw在线观看| 99国产精品视频免费观看一公开| 欧美一区二区三区在| 欧美激情一区二区在线 | 欧美日韩三级视频| 国语对白精品一区二区| 亚洲视频在线播放| 欧美福利电影网| 欧美在线观看网站| 欧美偷拍另类| 亚洲全黄一级网站| 久热精品视频在线观看| 亚洲综合色丁香婷婷六月图片| 欧美成人免费大片| 亚洲成色www8888| 久久综合狠狠| 午夜精品一区二区三区在线视| 欧美视频二区| 国产精品99久久久久久宅男| 亚洲激情综合| 欧美国产亚洲精品久久久8v| 激情av一区| 久久精品免费播放| 亚洲欧美视频一区| 国产精品自拍在线| 性色av一区二区三区红粉影视| 一区二区三区成人| 欧美视频不卡| 亚洲欧美在线高清| 在线视频一区观看| 国产精品久久久久久模特| 亚洲午夜精品在线| 亚洲视频一区二区| 国产精品亚洲欧美| 亚洲一区图片| 亚洲天堂成人在线观看| 国产精品乱码一区二三区小蝌蚪 | 国产欧美亚洲一区| 欧美一区二区久久久| 亚洲伊人网站| 国产综合久久久久久| 嫩模写真一区二区三区三州| 久久视频在线看| 亚洲精品免费一二三区| 亚洲日本视频| 国产精品区免费视频| 欧美在线亚洲| 看片网站欧美日韩| 亚洲高清二区| 亚洲国产一区在线| 欧美亚洲第一页| 久久爱www久久做| 久久久久女教师免费一区| 欧美肥婆在线| 亚洲视频在线二区| 欧美一区中文字幕| 亚洲精品美女免费| 午夜精品免费| 亚洲精品久久久久久下一站| 日韩小视频在线观看专区| 国产美女搞久久| 欧美成人激情在线| 国产精品久久久久aaaa樱花 | 日韩视频永久免费观看| 国产欧美一区二区三区视频| 毛片基地黄久久久久久天堂| 欧美二区在线观看| 欧美在线亚洲综合一区| 久久阴道视频| 亚洲在线电影| 麻豆91精品91久久久的内涵| 亚洲一区二区成人| 久久最新视频| 欧美在线视频观看| 欧美精品激情blacked18| 欧美在线三区| 国产精品草莓在线免费观看| 欧美成人免费全部| 国产精品亚洲精品| 亚洲美女网站| 91久久久久久| 欧美一区二视频| 亚洲一区bb| 欧美xxx成人| 裸体一区二区三区| 国产欧美三级| 亚洲私人影院| 9色精品在线| 免费成人激情视频| 久久夜色精品亚洲噜噜国产mv| 欧美午夜片在线观看| 亚洲激情偷拍| 亚洲第一区在线观看| 欧美一区二区三区在线看| 亚洲一区久久久| 欧美日韩你懂的| 日韩一区二区精品葵司在线| 亚洲人成在线播放| 麻豆精品视频在线观看视频| 久久久久国产精品一区三寸| 国产欧美va欧美不卡在线| 夜夜嗨av一区二区三区四季av| 日韩午夜激情| 欧美黑人国产人伦爽爽爽| 欧美jizz19hd性欧美| 国外成人在线| 久久久久99| 欧美成人免费在线观看| 狠狠网亚洲精品| 久久精品视频在线免费观看| 久久免费视频在线观看| 国产一区二区主播在线| 欧美在线亚洲一区| 美女视频黄免费的久久| 亚洲国产精品一区在线观看不卡 | 国产乱子伦一区二区三区国色天香| 一本综合久久| 午夜精品久久久久久久久久久久久 | 在线观看日韩| 久久亚洲美女| 欧美肥婆bbw| 亚洲免费福利视频| 欧美日韩另类在线| 亚洲视频在线观看网站| 欧美在线国产精品| 狠狠综合久久av一区二区老牛| 噜噜噜噜噜久久久久久91| 亚洲日本va在线观看| 亚洲女性裸体视频| 精品电影一区| 欧美日韩不卡视频| 亚洲一区免费网站| 久久精品中文字幕一区| 18成人免费观看视频| 欧美日韩国产大片| 亚洲女ⅴideoshd黑人| 欧美.com| 亚洲欧美激情四射在线日 | 国产精品嫩草久久久久| 久久久国产精彩视频美女艺术照福利| 美女91精品| 亚洲一品av免费观看| 一区在线播放| 欧美性大战久久久久久久| 久久高清免费观看| 亚洲美女视频| 免费亚洲网站| 亚洲欧美日韩国产一区| 一区二区三区在线免费观看| 欧美日韩国产麻豆| 久久久www免费人成黑人精品 | 亚洲福利久久| 欧美一区二区三区四区在线观看地址 | 美女精品在线观看| 中文日韩在线视频| 精久久久久久| 国产精品日日摸夜夜添夜夜av| 美女免费视频一区| 亚洲主播在线观看| 亚洲黄色在线视频| 久久综合狠狠综合久久综合88 | 欧美一区二区三区视频免费| 日韩网站在线看片你懂的| 在线观看亚洲一区| 国产区精品视频| 国产精品久久国产精麻豆99网站| 久久亚洲风情| 久久精品伊人| 欧美中文日韩| 午夜精品视频网站| 久久精品国产亚洲高清剧情介绍| 夜夜嗨av一区二区三区中文字幕|