c++builder CryptoAPI md5

#include <wincrypt.h>

DWORD GetHash(
    CONST BYTE * pbData,
    DWORD        dwDataLen,
    ALG_ID       algId,
    LPTSTR       pszHash )
{
    DWORD dwReturn = 0;
    HCRYPTPROV hProv;
    if ( !CryptAcquireContext( &hProv, NULL, NULL, PROV_RSA_FULL,
        CRYPT_VERIFYCONTEXT ) )
    {
        return ( dwReturn = GetLastError( ) );
    }

    HCRYPTHASH hHash;
    // Alg Id:CALG_MD5,CALG_SHA
    if ( !CryptCreateHash( hProv, algId, 0, 0, &hHash ) )
    {
        dwReturn = GetLastError( );
        CryptReleaseContext( hProv, 0 );
        return dwReturn;
    }

    if ( !CryptHashData( hHash, pbData, dwDataLen, 0 ) )
    {
        dwReturn = GetLastError( );
        CryptDestroyHash( hHash );
        CryptReleaseContext( hProv, 0 );
        return dwReturn;
    }

    DWORD dwSize;
    DWORD dwLen = sizeof( dwSize );
    CryptGetHashParam( hHash, HP_HASHSIZE, ( BYTE * )( & dwSize ), & dwLen, 0 );

    BYTE * pHash = new BYTE[ dwSize ];
    dwLen = dwSize;
    CryptGetHashParam( hHash, HP_HASHVAL, pHash, & dwLen, 0 );

    lstrcpy( pszHash, _T( "" ) );
    TCHAR szTemp[ 3 ];
    for ( DWORD i = 0; i < dwLen; ++i )
    {
        // wsprintf(szTemp, _T("%X%X"), pHash[i] >> 4, pHash[i] & 0xf);
        wsprintf( szTemp, L"%02X", pHash[ i ] );
        lstrcat( pszHash, szTemp );
    }
    delete[ ]pHash;

    CryptDestroyHash( hHash );
    CryptReleaseContext( hProv, 0 );
    return dwReturn;
}

void __fastcall TForm2::Button2Click( TObject * Sender )
{
    char szStr[ 20 ] =    {        0 } ;
    TCHAR szHash[ 41 ] = {    0    } ;

    strcpy( szStr, "ww" ); // wcscpy
    GetHash( ( BYTE * )szStr, strlen( szStr ), CALG_MD5, szHash );
    Caption = szHash;

    strcpy( szStr, "ww" ); // wcscpy
    GetHash( ( BYTE * )szStr, strlen( szStr ), CALG_MD5, szHash );
    Caption = szHash;
    //
    // strwcpy( szStr, "测试SHA" );
    // GetHash( ( BYTE * )szStr, strlen( szStr ), CALG_SHA, szHash );
    // MessageBox( NULL, szHash, szStr, MB_OK );
}
时间: 2024-10-11 13:08:55

c++builder CryptoAPI md5的相关文章

第五章 编码/加密——《跟我学Shiro》

在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shiro提供了base64和16进制字符串编码/解码的API支持,方便一些编码解码操作.Shiro内部的一些数据的存储/表示都使用了base64和16进制字符串. Java代码 String str = "hello"; String base64Encoded = Base64.encodeT

将 Shiro 作为应用的权限基础 五:密码的加密/解密在Spring中的应用

考虑系统密码的安全,目前大多数系统都不会把密码以明文的形式存放到数据库中. 一把会采取以下几种方式对密码进行处理 密码的存储 "编码"存储 Shiro 提供了 base64和 16 进制字符串编码/解码的 API支持,方便一些编码解码操作. Shiro内部的一些数据的存储/表示都使用了 base64和 16 进制字符串. 下面两端代码分别对其进行演示 Stringstr = "hello"; Stringbase64Encoded = Base64.encodeTo

shrio 加密/编码

在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shiro提供了base64和16进制字符串编码/解码的API支持,方便一些编码解码操作.Shiro内部的一些数据的存储/表示都使用了base64和16进制字符串. String str = "hello"; String base64Encoded = Base64.encodeToString

Shiro加密

在开发的时候,很多数据我们都希望是以加密过后的形式存储起来,而不是最原始的数据. 在shiro中也提供了编码,解码,加密,加密算法实现等等一系列的内容. 编码/解码 在org.apache.shiro.codec包中,提供了Base64,16进制等的编码解码工具类的实现. package com.fuwh.demo; import org.apache.shiro.codec.Base64; import org.apache.shiro.codec.Hex; public class Code

第5章 编码/加密

在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shiro提供了base64(Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一)和16进制字符串编码/解码的API支持,方便一些编码解码操作,Shiro内部的一些数据的存储/表示都使用了base64和16进制字符串. String str = "hello"; String ba

VC使用CryptoAPI计算MD5

// md5.h #include <tchar.h> #include <wincrypt.h> // 计算Hash,成功返回0,失败返回GetLastError() // CONST BYTE *pbData, // 输入数据 // DWORD dwDataLen, // 输入数据字节长度 // ALG_ID algId // Hash 算法:CALG_MD5,CALG_SHA // LPTSTR pszHash, // 输出16进制Hash字符串,MD5长度为32+1, SH

常用MD5算法代码

常用的MD5算法代码日期: 2014年8月4日作者: 铁锚 MD5,全称为 Message Digest Algorithm 5(消息摘要算法第五版).详情请参考 维基百科:MD5 MD5加密后是一个字节数组, 但我们一般是取其十六进制的字符串表示法,当然,十六进制数字符串是区分大小写,在 mysql数据库,Java,和JavaScript语言中,一般是使用小写的字符串来表示, 而在 Oracle数据库官方提供的包中,返回的是大写字符串,这算是一个坑,如果你想要执行多次 md5,可能需要转换为小

MD5工具类

public class MD5 { public static String getMD5(String content) { try { MessageDigest digest = MessageDigest.getInstance("MD5"); digest.update(content.getBytes()); return getHashString(digest); } catch (NoSuchAlgorithmException e) { e.printStackT

密码学应用(DES,AES, MD5, SHA1, RSA, Salt, Pkcs8)

目录 一.数据加密标准 - Data Encryption Standard(DES) 二.高级加密标准 - Advanced Encryption Standard(AES) 三.消息摘要算法第五版 - Message-Digest Algorithm 5(MD5) 四.安全哈希算法 - Secure Hash Algorithm(SHA1) 五.公钥加密算法(RSA) 六.干扰项 - 盐(Salt) 七.RSA密钥格式Pkcs8 八.源码下载 数据加密标准 - Data Encryption