from: http://blog.sina.com.cn/s/blog_693de6100101kcu6.html

注:以下是md5加密算法c语言版(16/32位)

---------------------------------------------------

网上找到的md5函数的实现,包括三个文件,依次如下:

头文件 TL_MD5.h

  1. [cpp]
  2. #ifndef MD5_H
  3. #define MD5_H
  4.  
  5. typedef struct
  6. {
  7. unsigned int count[];
  8. unsigned int state[];
  9. unsigned char buffer[];
  10. }MD5_CTX;
  11.  
  12. #define F(x,y,z) ((x & y) | (~x & z))
  13. #define G(x,y,z) ((x & z) | (y & ~z))
  14. #define H(x,y,z) (x^y^z)
  15. #define I(x,y,z) (y ^ (x | ~z))
  16. #define ROTATE_LEFT(x,n) ((x << n) | (x >> (32-n)))
  17. #define FF(a,b,c,d,x,s,ac) \
  18. { \
  19. a += F(b,c,d) + x + ac; \
  20. a = ROTATE_LEFT(a,s); \
  21. a += b; \
  22. }
  23. #define GG(a,b,c,d,x,s,ac) \
  24. { \
  25. a += G(b,c,d) + x + ac; \
  26. a = ROTATE_LEFT(a,s); \
  27. a += b; \
  28. }
  29. #define HH(a,b,c,d,x,s,ac) \
  30. { \
  31. a += H(b,c,d) + x + ac; \
  32. a = ROTATE_LEFT(a,s); \
  33. a += b; \
  34. }
  35. #define II(a,b,c,d,x,s,ac) \
  36. { \
  37. a += I(b,c,d) + x + ac; \
  38. a = ROTATE_LEFT(a,s); \
  39. a += b; \
  40. }
  41. void MD5Init(MD5_CTX *context);
  42. void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen);
  43. void MD5Final(MD5_CTX *context,unsigned char digest[]);
  44. void MD5Transform(unsigned int state[],unsigned char block[]);
  45. void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len);
  46. void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len);
  47.  
  48. #endif

C/C++语言实现文件 TL_MD5.c 或者 TL_MD5.cpp

  1. [cpp]
  2. #include <string.h>
  3. #include "md5.h"
  4.  
  5. unsigned char PADDING[]={0x80,,,,,,,,,,,,,,,,
  6. ,,,,,,,,,,,,,,,,
  7. ,,,,,,,,,,,,,,,,
  8. ,,,,,,,,,,,,,,,};
  9.  
  10. void MD5Init(MD5_CTX *context)
  11. {
  12. context->count[] = ;
  13. context->count[] = ;
  14. context->state[] = 0x67452301;
  15. context->state[] = 0xEFCDAB89;
  16. context->state[] = 0x98BADCFE;
  17. context->state[] = 0x10325476;
  18. }
  19. void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen)
  20. {
  21. unsigned int i = ,index = ,partlen = ;
  22. index = (context->count[] >> ) & 0x3F;
  23. partlen = - index;
  24. context->count[] += inputlen << ;
  25. if(context->count[] < (inputlen << ))
  26. context->count[]++;
  27. context->count[] += inputlen >> ;
  28.  
  29. if(inputlen >= partlen)
  30. {
  31. memcpy(&context->buffer[index],input,partlen);
  32. MD5Transform(context->state,context->buffer);
  33. for(i = partlen;i+ <= inputlen;i+=)
  34. MD5Transform(context->state,&input[i]);
  35. index = ;
  36. }
  37. else
  38. {
  39. i = ;
  40. }
  41. memcpy(&context->buffer[index],&input[i],inputlen-i);
  42. }
  43. void MD5Final(MD5_CTX *context,unsigned char digest[])
  44. {
  45. unsigned int index = ,padlen = ;
  46. unsigned char bits[];
  47. index = (context->count[] >> ) & 0x3F;
  48. padlen = (index < )?(-index):(-index);
  49. MD5Encode(bits,context->count,);
  50. MD5Update(context,PADDING,padlen);
  51. MD5Update(context,bits,);
  52. MD5Encode(digest,context->state,);
  53. }
  54. void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len)
  55. {
  56. unsigned int i = ,j = ;
  57. while(j < len)
  58. {
  59. output[j] = input[i] & 0xFF;
  60. output[j+] = (input[i] >> ) & 0xFF;
  61. output[j+] = (input[i] >> ) & 0xFF;
  62. output[j+] = (input[i] >> ) & 0xFF;
  63. i++;
  64. j+=;
  65. }
  66. }
  67. void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len)
  68. {
  69. unsigned int i = ,j = ;
  70. while(j < len)
  71. {
  72. output[i] = (input[j]) |
  73. (input[j+] << ) |
  74. (input[j+] << ) |
  75. (input[j+] << );
  76. i++;
  77. j+=;
  78. }
  79. }
  80. void MD5Transform(unsigned int state[],unsigned char block[])
  81. {
  82. unsigned int a = state[];
  83. unsigned int b = state[];
  84. unsigned int c = state[];
  85. unsigned int d = state[];
  86. unsigned int x[];
  87. MD5Decode(x,block,);
  88. FF(a, b, c, d, x[ ], , 0xd76aa478);
  89. FF(d, a, b, c, x[ ], , 0xe8c7b756);
  90. FF(c, d, a, b, x[ ], , 0x242070db);
  91. FF(b, c, d, a, x[ ], , 0xc1bdceee);
  92. FF(a, b, c, d, x[ ], , 0xf57c0faf);
  93. FF(d, a, b, c, x[ ], , 0x4787c62a);
  94. FF(c, d, a, b, x[ ], , 0xa8304613);
  95. FF(b, c, d, a, x[ ], , 0xfd469501);
  96. FF(a, b, c, d, x[ ], , 0x698098d8);
  97. FF(d, a, b, c, x[ ], , 0x8b44f7af);
  98. FF(c, d, a, b, x[], , 0xffff5bb1);
  99. FF(b, c, d, a, x[], , 0x895cd7be);
  100. FF(a, b, c, d, x[], , 0x6b901122);
  101. FF(d, a, b, c, x[], , 0xfd987193);
  102. FF(c, d, a, b, x[], , 0xa679438e);
  103. FF(b, c, d, a, x[], , 0x49b40821);
  104.  
  105. GG(a, b, c, d, x[ ], , 0xf61e2562);
  106. GG(d, a, b, c, x[ ], , 0xc040b340);
  107. GG(c, d, a, b, x[], , 0x265e5a51);
  108. GG(b, c, d, a, x[ ], , 0xe9b6c7aa);
  109. GG(a, b, c, d, x[ ], , 0xd62f105d);
  110. GG(d, a, b, c, x[], , 0x2441453);
  111. GG(c, d, a, b, x[], , 0xd8a1e681);
  112. GG(b, c, d, a, x[ ], , 0xe7d3fbc8);
  113. GG(a, b, c, d, x[ ], , 0x21e1cde6);
  114. GG(d, a, b, c, x[], , 0xc33707d6);
  115. GG(c, d, a, b, x[ ], , 0xf4d50d87);
  116. GG(b, c, d, a, x[ ], , 0x455a14ed);
  117. GG(a, b, c, d, x[], , 0xa9e3e905);
  118. GG(d, a, b, c, x[ ], , 0xfcefa3f8);
  119. GG(c, d, a, b, x[ ], , 0x676f02d9);
  120. GG(b, c, d, a, x[], , 0x8d2a4c8a);
  121.  
  122. HH(a, b, c, d, x[ ], , 0xfffa3942);
  123. HH(d, a, b, c, x[ ], , 0x8771f681);
  124. HH(c, d, a, b, x[], , 0x6d9d6122);
  125. HH(b, c, d, a, x[], , 0xfde5380c);
  126. HH(a, b, c, d, x[ ], , 0xa4beea44);
  127. HH(d, a, b, c, x[ ], , 0x4bdecfa9);
  128. HH(c, d, a, b, x[ ], , 0xf6bb4b60);
  129. HH(b, c, d, a, x[], , 0xbebfbc70);
  130. HH(a, b, c, d, x[], , 0x289b7ec6);
  131. HH(d, a, b, c, x[ ], , 0xeaa127fa);
  132. HH(c, d, a, b, x[ ], , 0xd4ef3085);
  133. HH(b, c, d, a, x[ ], , 0x4881d05);
  134. HH(a, b, c, d, x[ ], , 0xd9d4d039);
  135. HH(d, a, b, c, x[], , 0xe6db99e5);
  136. HH(c, d, a, b, x[], , 0x1fa27cf8);
  137. HH(b, c, d, a, x[ ], , 0xc4ac5665);
  138.  
  139. II(a, b, c, d, x[ ], , 0xf4292244);
  140. II(d, a, b, c, x[ ], , 0x432aff97);
  141. II(c, d, a, b, x[], , 0xab9423a7);
  142. II(b, c, d, a, x[ ], , 0xfc93a039);
  143. II(a, b, c, d, x[], , 0x655b59c3);
  144. II(d, a, b, c, x[ ], , 0x8f0ccc92);
  145. II(c, d, a, b, x[], , 0xffeff47d);
  146. II(b, c, d, a, x[ ], , 0x85845dd1);
  147. II(a, b, c, d, x[ ], , 0x6fa87e4f);
  148. II(d, a, b, c, x[], , 0xfe2ce6e0);
  149. II(c, d, a, b, x[ ], , 0xa3014314);
  150. II(b, c, d, a, x[], , 0x4e0811a1);
  151. II(a, b, c, d, x[ ], , 0xf7537e82);
  152. II(d, a, b, c, x[], , 0xbd3af235);
  153. II(c, d, a, b, x[ ], , 0x2ad7d2bb);
  154. II(b, c, d, a, x[ ], , 0xeb86d391);
  155. state[] += a;
  156. state[] += b;
  157. state[] += c;
  158. state[] += d;
  159. }

md5函数测试代码文件

  1. [cpp]
  2. #include
  3. #include
  4. #include
  5. #include "md5.h"
  6.  
  7. int main(int argc, char *argv[])
  8. {
  9. MD5_CTX md5;
  10. MD5Init(&md5);
  11. int i;
  12. unsigned char encrypt[] ="admin";//21232f297a57a5a743894a0e4a801fc3
  13. unsigned char decrypt[];
  14. MD5Update(&md5,encrypt,strlen((char *)encrypt));
  15. MD5Final(&md5,decrypt);
  16. printf("加密前:%s\n加密后16位:",encrypt);
  17. for(i=;i<;i++)
  18. {
  19. printf("02x",decrypt[i]); //02x前需要加上 %
  20. }
  21.  
  22. printf("\n加密前:%s\n加密后32位:",encrypt);
  23. for(i=;i<;i++)
  24. {
  25. printf("02x",decrypt[i]); //02x前需要加上 %
  26. }
  27.  
  28. getchar();
  29.  
  30. return ;
  31. }

MD5加密常用字符

7a57a5a743894a0e admin(16位MD5小写加密)
972130B75066C825 ADMIN(16位MD5大写加密)
21232f297a57a5a743894a0e4a801fc3 admin(32位MD5小写加密)
73ACD9A5972130B75066C82595A1FAE3 ADMIN(32位MD5大写加密)
49ba59abbe56e057 123456(16位MD5小写加密)
e10adc3949ba59abbe56e057f20f883e 123456(32位MD5小写加密)
469e80d32c0559f8 admin888(16位MD5小写加密)
2299413865C28A35 ADMIN888(16位MD5大写加密)
7fef6171469e80d32c0559f88b377245 admin888(32位MD5小写加密)
A1F63A962299413865C28A3593D359B0 ADMIN888(32位MD5大写加密)

md5知识扫盲

MD5:是一个散列算法,但非加密算法(因为没有密钥)
MD5是一种单向散列函数,单向散列函数的作用是将任何长度的一段数据散列成固定长度。常用于生成消息认证码等等,可以与非对称算法一起用于数字签名。
标准见http://www.ietf.org/rfc/rfc1321.txt

在线MD5计算 http://www.cmd5.com/

md5加密算法c语言版的更多相关文章

  1. MD5加密算法测试

    在用户注册这一块,密码加密保证客户信息安全是最重要的,在网上查询了一些资料,发现加密算法比较流行的有MD5,DES和SHA. 虽然SHA与MD5通过碰撞法被破解了,但是MD5和SHA仍被公认是安全的加 ...

  2. Windows 8.1 with Update 镜像下载(增OEM单语言版)

    该系统已有更新的版本,请转至<Windows 8.1 with update 官方最新镜像汇总>下载. 2014年4月9日凌晨,微软向MSDN订阅用户开放了Windows 8.1 with ...

  3. MD5加密算法(java及js)

    为了防止用户登陆过程中信息被拦截导致信息泄露,我们应该在客户端就对用户密码进行加密.浏览器提交给服务器的是加密后的信息,即使被恶意拦截,被拦截信息也已做了加密处理,现在比较安全的一种加密算法是MD5加 ...

  4. Java学习---MD5加密算法

    前言 在我们日常的程序开发中,或多或少会遇到一些加密/解密的场景,比如在一些接口调用的过程中,我们(Client)不仅仅需要传递给接口服务(Server)必要的业务参数,还得提供Signature(数 ...

  5. 一起谈谈MD5加密算法

    MD5是一个安全的散列算法,输入两个不同的明文不会得到相同的输出值,根据输出值,不能得到原始的明文,即其过程不可逆:所以要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后 ...

  6. libnode 0.4.0 发布,C++ 语言版的 Node.js

    libnode 0.4.0 支持 Windows ,提升了性能,libuv 更新到 0.10.17 版本,libj 更新到 0.8.2 版本. libnode 是 C++ 语言版的 Node.js,和 ...

  7. MD5加密算法

    package com.bao.tools.encryption; import java.security.MessageDigest;import java.security.NoSuchAlgo ...

  8. 基于gSOAP使用头文件的C语言版web service开发过程例子

    基于gSOAP使用头文件的C语言版web service开发过程例子 一服务端 1 打开VS2005,创建一个工程,命名为calcServer. 2 添加一个头文件calc.h,编辑内容如下: 1// ...

  9. 标准MD5加密算法

    标准MD5加密算法: public class Md5 { public static String getMd5(String s) { char hexDigits[] = { '0', '1', ...

随机推荐

  1. HDU 4647 Another Graph Game 思路+贪心

    官方题解: 若没有边权,则对点权从大到小排序即可.. 考虑边,将边权拆成两半加到它所关联的两个点的点权中即可. ..因为当两个人分别选择不同的点时,这一权值将互相抵消. #include <cs ...

  2. git 创建branch分支【转】

    转自:http://www.cnblogs.com/jackluo/p/3499731.html 开发者user1 负责用getopt 进行命令解析的功能,因为这个功能用到getopt 函数,于是将这 ...

  3. Ubuntu 安装vsftp软件(已测试)

    首先开启Ftp端口 使用apt-get命令安装vsftp #apt-get install vsftpd -y 添加ftp帐号和目录 先检查一下nologin的位置,通常在/usr/sbin/nolo ...

  4. .NET Framework 4.5 五个很棒的特性

    转自http://news.cnblogs.com/n/192958/ 英文原文:Five Great .NET Framework 4.5 Features 简介 自 .NET 4.5 发布已经过了 ...

  5. maven3实战之设置HTTP代理

    maven3实战之设置HTTP代理 ---------- 有时候你所在的公司基于安全因素考虑,要求你使用通过安全认证的代理访问因特网.这种情况下,就需要为Maven配置HTTP代理,才能让它正常访问外 ...

  6. Spring安全框架 Spring Security

    Spring Security 的前身是 Acegi Security ,是 Spring 项目组中用来提供安全认证服务的框架. Spring Security  为基于J2EE企业应用软件提供了全面 ...

  7. js案例_下滑列表

    1.HTML布局(使用ul): <body> <ul> <li class="list" id="lis"> <a h ...

  8. Qt之透明提示框

    简述 经常使用企鹅的小伙伴一定对登录失败的提示框很熟悉,主要涉及窗口透明并添加图标.提示信息.关闭按钮的显示等. 我们可以利用QWidget创建一个提示框,然后通过样式设置我们想要的效果. 简述 效果 ...

  9. BZOJ 1003 物流运输

    最短路+dp. #include<iostream> #include<cstdio> #include<cstring> #include<algorith ...

  10. android 呼入电话的监听(来电监听)转

    需要权限: <uses-permission android:name="android.permission.READ_PHONE_STATE" /> 方式一:通过广 ...