#include <wincrypt.h>

DWORD GetHash(
CONST BYTE * pbData,
DWORD dwDataLen,
ALG_ID algId,
LPTSTR pszHash )
{
DWORD dwReturn = ;
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, , , &hHash ) )
{
dwReturn = GetLastError( );
CryptReleaseContext( hProv, );
return dwReturn;
} if ( !CryptHashData( hHash, pbData, dwDataLen, ) )
{
dwReturn = GetLastError( );
CryptDestroyHash( hHash );
CryptReleaseContext( hProv, );
return dwReturn;
} DWORD dwSize;
DWORD dwLen = sizeof( dwSize );
CryptGetHashParam( hHash, HP_HASHSIZE, ( BYTE * )( & dwSize ), & dwLen, ); BYTE * pHash = new BYTE[ dwSize ];
dwLen = dwSize;
CryptGetHashParam( hHash, HP_HASHVAL, pHash, & dwLen, ); lstrcpy( pszHash, _T( "" ) );
TCHAR szTemp[ ];
for ( DWORD i = ; 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, );
return dwReturn;
} void __fastcall TForm2::Button2Click( TObject * Sender )
{
char szStr[ ] = { } ;
TCHAR szHash[ ] = { } ; 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 );
}

多数时候这个函数的dwProvType使用PROV_RSA_FULL(网上的开源代码基本都是使用这个常数),这对MD5,SHA-1等都有效;但是却不是正确的SHA-256/512的provider type,所以使用这个常数创建的context会在之后创建SHA-256/512算法时发生错误。

正确的做法是使用PROV_RSA_AES

from http://blog.kingsamchen.com/archives/tag/sha

c++builder CryptoAPI md5的更多相关文章

  1. c++Builder XE6 MD5 加密算法 BASE64 URL 编码

    xe6,xe7 BASE64XE6 MD5 加密算法Delphifunction MD5(const texto: string): string; var idmd5: TIdHashMessage ...

  2. 跟开涛老师学shiro -- 编码/加密

    在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shir ...

  3. 将 Shiro 作为一个许可为基础的应用程序 五:password加密/解密Spring应用

    考虑系统password的安全,眼下大多数系统都不会把password以明文的形式存放到数据库中. 一把会採取下面几种方式对password进行处理 password的存储 "编码" ...

  4. Shiro加密

    在开发的时候,很多数据我们都希望是以加密过后的形式存储起来,而不是最原始的数据. 在shiro中也提供了编码,解码,加密,加密算法实现等等一系列的内容. 编码/解码 在org.apache.shiro ...

  5. shiro中编码/加密

    在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shir ...

  6. shrio 加密/编码

    在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shir ...

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

    转发地址:https://www.iteye.com/blog/jinnianshilongnian-2021439 目录贴:跟我学Shiro目录贴 在涉及到密码存储问题上,应该加密/生成密码摘要存储 ...

  8. (七)shiro之编码/加密

    一.编码/解码 使用Base64编码/解码操作 public class TestMain { public static void main(String[] args) { SecurityMan ...

  9. Shiro学习(5)编码、加密

    在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码.比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储. 5.1 编码/解码 Shir ...

随机推荐

  1. spring 定时器设置每隔10秒触发

    <property name="cronExpression" value="0/10 * * * * ?" />

  2. C# 对List成员排序的简单方法

    网上看到的方法,实在太方便了,转过来保存,原链接: http://blog.csdn.net/wanzhuan2010/article/details/6205884 using System; us ...

  3. Jquery源码中的Javascript基础知识(一)

    jquery源码中涉及了大量原生js中的知识和概念,文章是我在学习两者的过程中进行的整理和总结,有不对的地方欢迎大家指正. 本文使用的jq版本为2.0.3,附上压缩和未压缩版本地址: http://a ...

  4. Web Api 在线参考文档

    参考文档: https://developer.mozilla.org/zh-CN/docs/Web/API

  5. 在ACCESS中创建数据库和查询(ACCESS 2000)

    备份还原数据库 备份.还原 —— 复制\粘贴 压缩修复数据库命令 —— 复制该文件并重新组织,并重新组织文件在磁盘上的储存方式.压缩同时优化了Access数据库的性能.(工具——实用数据库工具或者工具 ...

  6. 用list<类>集合接收一个网址返回的一个类的集合的XML

    JavaScriptSerializer serializer = new JavaScriptSerializer(); string json = Share.Helper.HttpRequest ...

  7. (win+linux)双系统,删除linux系统的条件下,删除grub引导记录,恢复windows引导

    //(hdx,y) (显示查找到的分区号)第一个数字指第几个硬盘,第二个指第几个分区.   一般我们是(hd0,0) \n Linux的分区已经被你从Windows中删除,系统启动后停在“grub&g ...

  8. getHibernateTemplate() 一直报NullPointerException 错误

    原来是调用方法有误正确调用方法: ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContex ...

  9. C++模板实例掌握

    前段时间重新学习C++,主要看C++编程思想和C++设计新思维.对模版的使用有了更进一层的了解,特总结如下: 下面列出了模版的常用情况:  << '\n';} //参考:http://ww ...

  10. 9、NFC技术:NDEF文本格式解析

    NDEF文本格式规范     不管什么格式的数据本质上都是由一些字节组成的.对于NDEF文本格式来说.这些数据的第1个字节描述了数据的状态,然后若干个字节描述文本的语言编码,最后剩余字节表示文本数据. ...