#ifndef MD5_CHECK_SUM_HEAD #define MD5_CHECK_SUM_HEAD #pragma once #include "ServiceCoreHead.h" /////////////////////////////////////////////////////////////////////////////////////// //初始常量 #define MD5_INIT_STATE_0 0x67452301 #define MD5_INIT_STATE_1 0xefcdab89 #define MD5_INIT_STATE_2 0x98badcfe #define MD5_INIT_STATE_3 0x10325476 //转换常量 #define MD5_S11 7 #define MD5_S12 12 #define MD5_S13 17 #define MD5_S14 22 #define MD5_S21 5 #define MD5_S22 9 #define MD5_S23 14 #define MD5_S24 20 #define MD5_S31 4 #define MD5_S32 11 #define MD5_S33 16 #define MD5_S34 23 #define MD5_S41 6 #define MD5_S42 10 #define MD5_S43 15 #define MD5_S44 21 //1轮转换常量 #define MD5_T01 0xd76aa478 #define MD5_T02 0xe8c7b756 #define MD5_T03 0x242070db #define MD5_T04 0xc1bdceee #define MD5_T05 0xf57c0faf #define MD5_T06 0x4787c62a #define MD5_T07 0xa8304613 #define MD5_T08 0xfd469501 #define MD5_T09 0x698098d8 #define MD5_T10 0x8b44f7af #define MD5_T11 0xffff5bb1 #define MD5_T12 0x895cd7be #define MD5_T13 0x6b901122 #define MD5_T14 0xfd987193 #define MD5_T15 0xa679438e #define MD5_T16 0x49b40821 //2轮转换常量 #define MD5_T17 0xf61e2562 #define MD5_T18 0xc040b340 #define MD5_T19 0x265e5a51 #define MD5_T20 0xe9b6c7aa #define MD5_T21 0xd62f105d #define MD5_T22 0x02441453 #define MD5_T23 0xd8a1e681 #define MD5_T24 0xe7d3fbc8 #define MD5_T25 0x21e1cde6 #define MD5_T26 0xc33707d6 #define MD5_T27 0xf4d50d87 #define MD5_T28 0x455a14ed #define MD5_T29 0xa9e3e905 #define MD5_T30 0xfcefa3f8 #define MD5_T31 0x676f02d9 #define MD5_T32 0x8d2a4c8a //3轮转换常量 #define MD5_T33 0xfffa3942 #define MD5_T34 0x8771f681 #define MD5_T35 0x6d9d6122 #define MD5_T36 0xfde5380c #define MD5_T37 0xa4beea44 #define MD5_T38 0x4bdecfa9 #define MD5_T39 0xf6bb4b60 #define MD5_T40 0xbebfbc70 #define MD5_T41 0x289b7ec6 #define MD5_T42 0xeaa127fa #define MD5_T43 0xd4ef3085 #define MD5_T44 0x04881d05 #define MD5_T45 0xd9d4d039 #define MD5_T46 0xe6db99e5 #define MD5_T47 0x1fa27cf8 #define MD5_T48 0xc4ac5665 //4轮转换常量 #define MD5_T49 0xf4292244 #define MD5_T50 0x432aff97 #define MD5_T51 0xab9423a7 #define MD5_T52 0xfc93a039 #define MD5_T53 0x655b59c3 #define MD5_T54 0x8f0ccc92 #define MD5_T55 0xffeff47d #define MD5_T56 0x85845dd1 #define MD5_T57 0x6fa87e4f #define MD5_T58 0xfe2ce6e0 #define MD5_T59 0xa3014314 #define MD5_T60 0x4e0811a1 #define MD5_T61 0xf7537e82 #define MD5_T62 0xbd3af235 #define MD5_T63 0x2ad7d2bb #define MD5_T64 0xeb86d391 //填充数据 static unsigned char PADDING[64] = { 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; /////////////////////////////////////////////////////////////////////////////////////// //MD5校验 class SERVICE_CORE_CLASS CWHMD5Checksum { //存储变量 private: BYTE m_lpszBuffer[64]; //输入缓冲 ULONG m_nCount[2]; //位数计数 ULONG m_lMD5[4]; //MD5校验和 //函数定义 protected: CWHMD5Checksum(); virtual ~CWHMD5Checksum(); //静态函数 public: static CString GetMD5(BYTE* pBuf, UINT nLength); static CString GetMD5(CFile& File); static CString GetMD5(const CString& strFilePath); //辅助函数 protected: CString Final(); //辅助函数 protected: VOID Transform(BYTE Block[64]); VOID Update(BYTE* Input, ULONG nInputLen); VOID DWordToByte(BYTE* Output, DWORD* Input, UINT nLength); VOID ByteToDWord(DWORD* Output, BYTE* Input, UINT nLength); //内联函数 protected: inline DWORD RotateLeft(DWORD x, int n); inline VOID FF(DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T); inline VOID GG(DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T); inline VOID HH(DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T); inline VOID II(DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T); }; /////////////////////////////////////////////////////////////////////////////////////// #endif