请问:MD5同一字符串用不同的函数加密后的结果是否相同
请教:MD5同一字符串用不同的函数加密后的结果是否相同?
对字符串: test1
我用ASP.net的FormsAuthentication.HashPasswordForStoringInConfigFile(tbxpwd.Text,"MD5")加密存放在数据库。
客户端用如下代码:
#include "stdafx.h"
#include <windows.h>
/* Data structure for MD5 (Message-Digest) computation */
typedef struct {
ULONG i[2]; /* number of _bits_ handled mod 2^64 */
ULONG buf[4]; /* scratch buffer */
unsigned char in[64]; /* input buffer */
unsigned char digest[16]; /* actual digest after MD5Final call */
} MD5_CTX;
#define MD5DIGESTLEN 16
#define PROTO_LIST(list) list
/*
* MTS: Each of these assumes MD5_CTX is locked against simultaneous use.
*/
typedef void (WINAPI* PMD5Init) PROTO_LIST ((MD5_CTX *));
typedef void (WINAPI* PMD5Update) PROTO_LIST ((MD5_CTX *, const unsigned char *, unsigned int));
typedef void (WINAPI* PMD5Final )PROTO_LIST ((MD5_CTX *));
PMD5Init MD5Init = NULL;
PMD5Update MD5Update = NULL;
PMD5Final MD5Final = NULL;
const char *Hex2ASC(const BYTE *Hex, int Len)
{
static char ASC[4096 * 2];
int i;
for (i = 0; i < Len; i++)
{
ASC[i * 2] = "0123456789ABCDEF"[Hex[i] >> 4];
ASC[i * 2 + 1] = "0123456789ABCDEF"[Hex[i] & 0x0F];
}
ASC[i * 2] = '\0';
return ASC;
}
int main()
{
MD5_CTX ctx;
unsigned char buf[] = "test1";
HINSTANCE hDLL;
//if ( (hDLL = LoadLibrary(TEXT("advapi32.dll"))) > 0 )
if ( (hDLL = LoadLibrary(TEXT("Cryptdll.dll"))) > 0 )
{
MD5Init = (PMD5Init)GetProcAddress(hDLL,"MD5Init");
MD5Update = (PMD5Update)GetProcAddress(hDLL,"MD5Update");
MD5Final = (PMD5Final)GetProcAddress(hDLL,"MD5Final");
MD5Init(&ctx);
MD5Update(&ctx,buf,sizeof(buf));
MD5Final(&ctx);
for(int i=0; i<16; i++)
printf("%x", ctx.digest[i]);
printf("\n");
printf(Hex2ASC(ctx.digest,16));
FreeLibrary(hDLL);
}
return 0;
}
但加密的结果和asp.net加密的不相同,请问这现象正常吗?
谢谢!
------解决方案--------------------
同一方法一定相同
不同方法可能不同
------解决方案--------------------
http://blog.****.net/zgl7903/article/details/5692156
------解决方案--------------------
相同的输入数据------产生相同的16字节的md5结果。
不同的输入数据有可能产生相同的16字节的md5结果。
------解决方案--------------------
unsigned char buf[] = "test1";
这段代码中,与你后面的调用
MD5Update(&ctx,buf,sizeof(buf));
配合起来就是
//md5_hash ( ansi_string ( "test1\0" ) )
//----ansi_string convert utf16-little-endian format input data to ansi format
//---- input = 74 00 65 00 73 00 74 00 31 00 00 00
//---- output = 74 65 73 74 31 00
//
//--md5 hash
//-- input = 74 65 73 74 31 00
//-- output = 3C A4 36 BB ED 3F 13 E5 3D A8 7E AF 6F 71 68 2B
//
//-----最终计算结果 --- 3C A4 36 BB ED 3F 13 E5 3D A8 7E AF 6F 71 68 2B
//
跟俺贴的不一样的结果,就算错了。
对字符串: test1
我用ASP.net的FormsAuthentication.HashPasswordForStoringInConfigFile(tbxpwd.Text,"MD5")加密存放在数据库。
客户端用如下代码:
#include "stdafx.h"
#include <windows.h>
/* Data structure for MD5 (Message-Digest) computation */
typedef struct {
ULONG i[2]; /* number of _bits_ handled mod 2^64 */
ULONG buf[4]; /* scratch buffer */
unsigned char in[64]; /* input buffer */
unsigned char digest[16]; /* actual digest after MD5Final call */
} MD5_CTX;
#define MD5DIGESTLEN 16
#define PROTO_LIST(list) list
/*
* MTS: Each of these assumes MD5_CTX is locked against simultaneous use.
*/
typedef void (WINAPI* PMD5Init) PROTO_LIST ((MD5_CTX *));
typedef void (WINAPI* PMD5Update) PROTO_LIST ((MD5_CTX *, const unsigned char *, unsigned int));
typedef void (WINAPI* PMD5Final )PROTO_LIST ((MD5_CTX *));
PMD5Init MD5Init = NULL;
PMD5Update MD5Update = NULL;
PMD5Final MD5Final = NULL;
const char *Hex2ASC(const BYTE *Hex, int Len)
{
static char ASC[4096 * 2];
int i;
for (i = 0; i < Len; i++)
{
ASC[i * 2] = "0123456789ABCDEF"[Hex[i] >> 4];
ASC[i * 2 + 1] = "0123456789ABCDEF"[Hex[i] & 0x0F];
}
ASC[i * 2] = '\0';
return ASC;
}
int main()
{
MD5_CTX ctx;
unsigned char buf[] = "test1";
HINSTANCE hDLL;
//if ( (hDLL = LoadLibrary(TEXT("advapi32.dll"))) > 0 )
if ( (hDLL = LoadLibrary(TEXT("Cryptdll.dll"))) > 0 )
{
MD5Init = (PMD5Init)GetProcAddress(hDLL,"MD5Init");
MD5Update = (PMD5Update)GetProcAddress(hDLL,"MD5Update");
MD5Final = (PMD5Final)GetProcAddress(hDLL,"MD5Final");
MD5Init(&ctx);
MD5Update(&ctx,buf,sizeof(buf));
MD5Final(&ctx);
for(int i=0; i<16; i++)
printf("%x", ctx.digest[i]);
printf("\n");
printf(Hex2ASC(ctx.digest,16));
FreeLibrary(hDLL);
}
return 0;
}
但加密的结果和asp.net加密的不相同,请问这现象正常吗?
谢谢!
------解决方案--------------------
同一方法一定相同
不同方法可能不同
------解决方案--------------------
http://blog.****.net/zgl7903/article/details/5692156
------解决方案--------------------
相同的输入数据------产生相同的16字节的md5结果。
不同的输入数据有可能产生相同的16字节的md5结果。
------解决方案--------------------
unsigned char buf[] = "test1";
这段代码中,与你后面的调用
MD5Update(&ctx,buf,sizeof(buf));
配合起来就是
//md5_hash ( ansi_string ( "test1\0" ) )
//----ansi_string convert utf16-little-endian format input data to ansi format
//---- input = 74 00 65 00 73 00 74 00 31 00 00 00
//---- output = 74 65 73 74 31 00
//
//--md5 hash
//-- input = 74 65 73 74 31 00
//-- output = 3C A4 36 BB ED 3F 13 E5 3D A8 7E AF 6F 71 68 2B
//
//-----最终计算结果 --- 3C A4 36 BB ED 3F 13 E5 3D A8 7E AF 6F 71 68 2B
//
跟俺贴的不一样的结果,就算错了。