⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 md2.cpp

📁 含有多种公开密钥算法、多种块加密、多种数据流加密、多种HASH函数、多种CheckSum校验、多种MAC校验等几十种加密算法的程序
💻 CPP
字号:
/************************************************** MD2 Source File                                ** (C) 1999-2002 The Botan Project                **************************************************/#include <botan/md2.h>namespace Botan {/************************************************** MD2 Hash                                       **************************************************/void MD2::hash(const byte input[])   {   X.copy(16, input, HASH_BLOCK_SIZE);   xor_buf(X + 32, X, X + 16, HASH_BLOCK_SIZE);   byte T = 0;   for(u32bit j = 0; j != 18; j++)      {      for(u32bit k = 0; k != 48; k += 8)         {         T = X[k  ] ^= SBOX[T]; T = X[k+1] ^= SBOX[T];         T = X[k+2] ^= SBOX[T]; T = X[k+3] ^= SBOX[T];         T = X[k+4] ^= SBOX[T]; T = X[k+5] ^= SBOX[T];         T = X[k+6] ^= SBOX[T]; T = X[k+7] ^= SBOX[T];         }      T += j;      }   T = checksum[15];   for(u32bit j = 0; j != HASH_BLOCK_SIZE; j++)      T = checksum[j] ^= SBOX[input[j] ^ T];   }/************************************************** Finalize a MD2 Hash                            **************************************************/void MD2::final_result(byte output[])   {   for(u32bit j = position; j != HASH_BLOCK_SIZE; j++)      buffer[j] = (byte)(HASH_BLOCK_SIZE - position);   hash(buffer);   hash(checksum);   copy_mem(output, X.ptr(), OUTPUT_LENGTH);   clear();   }/************************************************** Clear memory of sensitive data                 **************************************************/void MD2::clear() throw()   {   X.clear();   checksum.clear();   buffer.clear();   position = 0;   }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -