MD5源代碼C++

// 計算文件
BOOL Hash::Hash_PatchFile(const char * sFileName,unsigned long nSkipSize,unsigned long nMaxReadSize)
{
    BYTE buffer[10240];
    int nReadSize;

    CBuffedFile reader(sFileName,FALSE,FALSE);
    if(!reader.IsOpened()) return FALSE;
    if(nMaxReadSize==0) nMaxReadSize = reader.GetFileSize();
    reader.Seek((int)nSkipSize);
    while(1)
    {
        nReadSize = (nMaxReadSize>10240)? 10240:nMaxReadSize;
        nReadSize = reader.Read(buffer,1, nReadSize);
        if(nReadSize < 0) return FALSE;
        Update(buffer,nReadSize);
        if(nReadSize < 10240) break;
        if(nMaxReadSize>0) nMaxReadSize -= nReadSize;
    }
    reader.Close();
    return TRUE;
}

// 結束處理 
CString Hash::Hash_End()
{
    SafeBuffer sWrkStr(nKeySize);
    Final((BYTE*)sWrkStr.GetBuffer());
    return BinToHex((BYTE *)sWrkStr.GetBuffer(),nKeySize);
}

//
// MD5
//

// MD5 初始化
void MD5::Init()
{
    // 獲取當前時間
    #ifdef _INVALID_DATE
        char sWrkStr[81];
        tm* pTime;
        time_t t;
        time(&t);
        pTime = localtime(&t); 
        sprintf(sWrkStr,"%04d%02d%02d", pTime->tm_year + 1900, pTime->tm_mon+1, pTime->tm_mday +1);
        if(strcmp(sWrkStr,_INVALID_DATE)>0)
        {
            fprintf(stderr,"Warning: \n");
            fprintf(stderr,"    this library is invalid!\n");
            fprintf(stderr,"    please contact Ylink Computing System LTD.ShenZhen!\n");
            return;
        }
    #endif
    nKeySize  = sizeof(digest);  // 4x4=16x8=128 bits
    nCount[0] = nCount[1] = 0;
    digest[0] = 0x67452301;
    digest[1] = 0xefcdab89;
    digest[2] = 0x98badcfe;
    digest[3] = 0x10325476;
    memset(buffer,0,sizeof(buffer));
}

// MD5 編碼一段數據
void MD5::Update(BYTE * InBuffer,WORD32 nSize)
{
    unsigned long i,index,partLen;

    index = ((nCount[0]>>3) & 0x3F);        // 前次模64後剩餘字節數
    nCount[0] += (nSize << 3);              // 累加總位數低位(字節數x8)
    nCount[1] += (nSize >> 29);             // 累加總位數高位
    if (nCount[0]<(nSize<<3)) nCount[1] ++; // 低位發生溢出,高位進位

    partLen = 64 - index;
    if (nSize >= partLen)
    {
        memcpy((BYTE *)buffer + index,InBuffer,(int)partLen);
        CorrectEndianess((WORD32 *)buffer,(WORD32 *) buffer,64);  // 校訂字節高低位
        Transform((WORD32 *)buffer);        // 先轉換前次剩餘的+本次補充的
        for (i=partLen;i+63<nSize;i+=64)    // 再每次處理64字節
        {
            CorrectEndianess((WORD32 *)buffer,(WORD32 *)&InBuffer[i],64); // 校訂
            Transform((WORD32 *)buffer);
        }
        index = 0;
    }
    else i = 0;

    // 將剩餘的留到下次處理
    memcpy(buffer + index,InBuffer + i,(int)(nSize - i));
}
相關文章
相關標籤/搜索