取文件MD5 WINAPI

 1 #include 
 2 #include 
 3 #include 
 4 
 5 BOOL GetFileHash(LPCSTR lpFileName, LPSTR lpHash)
 6 {
 7     BOOL bResult = FALSE;
 8 
 9     HANDLE hFile = CreateFile(lpFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
10 
11     if (hFile != INVALID_HANDLE_VALUE)
12     {
13         DWORD dwFileSize = GetFileSize(hFile, NULL);
14 
15         if (dwFileSize > 0)
16         {
17             PBYTE lpBuffer = (PBYTE)VirtualAlloc(NULL, dwFileSize, MEM_COMMIT, PAGE_READWRITE);
18 
19             if (lpBuffer != NULL)
20             {
21                 DWORD dwNumOfRead;
22 
23                 if (ReadFile(hFile, lpBuffer, dwFileSize, &dwNumOfRead, NULL) != FALSE)
24                 {
25                     HCRYPTPROV hProv;
26 
27                     if (CryptAcquireContext(&hProv, NULL, NULL, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT) != FALSE)
28                     {
29                         HCRYPTHASH hHash;
30 
31                         if (CryptCreateHash(hProv, CALG_MD5, NULL, NULL, &hHash) != FALSE)
32                         {
33                             if (CryptHashData(hHash, lpBuffer, dwFileSize, NULL) != FALSE)
34                             {
35                                 BYTE bData[16]; DWORD dwDataLen;
36 
37                                 if (CryptGetHashParam(hHash, HP_HASHVAL, bData, &dwDataLen, NULL) != FALSE)
38                                 {
39                                     if (dwDataLen == 16)
40                                     {
41                                         LPSTR lpStr = lpHash;
42 
43                                         for (DWORD i = 0; i < dwDataLen; i++, lpStr += 2)
44                                         {
45                                             sprintf(lpStr, "%02X", bData[i]);
46                                         }
47 
48                                         bResult = TRUE;
49                                     }
50                                 }
51                             }
52 
53                             CryptDestroyHash(hHash);
54                         }
55 
56                         CryptReleaseContext(hProv, NULL);
57                     }
58                 }
59 
60                 VirtualFree(lpBuffer, 0, MEM_RELEASE);
61             }
62         }
63 
64         CloseHandle(hFile);
65     }
66 
67     return bResult;
68 }

 

你可能感兴趣的:(取文件MD5 WINAPI)