快速业务通道

MD5应用的一点理解及Linux实现源码

作者 佚名技术 来源 Linux系统 浏览 发布时间 2012-04-05
the central step in the MD5 algorithm. */ #define MD5STEP(f, w, x, y, z, data, s) ( w = f(x, y, z) data, w = w<>(32-s), w = x ) /* * The core of the MD5 algorithm, this alters an existing MD5 hash to * reflect the addition of 16 longwords of new data. MD5Update blocks * the data and converts bytes into longwords for this routine. */ void MD5Transform(uint32 buf[4], uint32 const in[16]) { register uint32 a, b, c, d; a = buf[0]; b = buf[1]; c = buf[2]; d = buf[3]; MD5STEP(F1, a, b, c, d, in[0] 0xd76aa478, 7); MD5STEP(F1, d, a, b, c, in[1] 0xe8c7b756, 12); MD5STEP(F1, c, d, a, b, in[2] 0x242070db, 17); MD5STEP(F1, b, c, d, a, in[3] 0xc1bdceee, 22); MD5STEP(F1, a, b, c, d, in[4] 0xf57c0faf, 7); MD5STEP(F1, d, a, b, c, in[5] 0x4787c62a, 12); MD5STEP(F1, c, d, a, b, in[6] 0xa8304613, 17); MD5STEP(F1, b, c, d, a, in[7] 0xfd469501, 22); MD5STEP(F1, a, b, c, d, in[8] 0x698098d8, 7); MD5STEP(F1, d, a, b, c, in[9] 0x8b44f7af, 12); MD5STEP(F1, c, d, a, b, in[10] 0xffff5bb1, 17); MD5STEP(F1, b, c, d, a, in[11] 0x895cd7be, 22); MD5STEP(F1, a, b, c, d, in[12] 0x6b901122, 7); MD5STEP(F1, d, a, b, c, in[13] 0xfd987193, 12); MD5STEP(F1, c, d, a, b, in[14] 0xa679438e, 17); MD5STEP(F1, b, c, d, a, in[15] 0x49b40821, 22); MD5STEP(F2, a, b, c, d, in[1] 0xf61e2562, 5); MD5STEP(F2, d, a, b, c, in[6] 0xc040b340, 9); MD5STEP(F2, c, d, a, b, in[11] 0x265e5a51, 14); MD5STEP(F2, b, c, d, a, in[0] 0xe9b6c7aa, 20); MD5STEP(F2, a, b, c, d, in[5] 0xd62f105d, 5); MD5STEP(F2, d, a, b, c, in[10] 0x02441453, 9); MD5STEP(F2, c, d, a, b, in[15] 0xd8a1e681, 14); MD5STEP(F2, b, c, d, a, in[4] 0xe7d3fbc8, 20); MD5STEP(F2, a, b, c, d, in[9] 0x21e1cde6, 5); MD5STEP(F2, d, a, b, c, in[14] 0xc33707d6, 9); MD5STEP(F2, c, d, a, b, in[3] 0xf4d50d87, 14); MD5STEP(F2, b, c, d, a, in[8] 0x455a14ed, 20); MD5STEP(F2, a, b, c, d, in[13] 0xa9e3e905, 5); MD5STEP(F2, d, a, b, c, in[2] 0xfcefa3f8, 9); MD5STEP(F2, c, d, a, b, in[7] 0x676f02d9, 14); MD5STEP(F2, b, c, d, a, in[12] 0x8d2a4c8a, 20); MD5STEP(F3, a, b, c, d, in[5] 0xfffa3942, 4); MD5STEP(F3, d, a, b, c, in[8] 0x8771f681, 11); MD5STEP(F3, c, d, a, b, in[11] 0x6d9d6122, 16); MD5STEP(F3, b, c, d, a, in[14] 0xfde5380c, 23); MD5STEP(F3, a, b, c, d, in[1] 0xa4beea44, 4); MD5STEP(F3, d, a, b, c, in[4] 0x4bdecfa9, 11); MD5STEP(F3, c, d, a, b, in[7] 0xf6bb4b60, 16); MD5STEP(F3, b, c, d, a, in[10] 0xbebfbc70, 23); MD5STEP(F3, a, b, c, d, in[13] 0x289b7ec6, 4); MD5STEP(F3, d, a, b, c, in[0] 0xeaa127fa, 11); MD5STEP(F3, c, d, a, b, in[3] 0xd4ef3085, 16); MD5STEP(F3, b, c, d, a, in[6] 0x04881d05, 23); MD5STEP(F3, a, b, c, d, in[9] 0xd9d4d039, 4); MD5STEP(F3, d, a, b, c, in[12] 0

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号