请问: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
//
跟俺贴的不一样的结果,就算错了。