MD5.js 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. /**
  2. * Created by william on 2016/7/27.
  3. */
  4. /*
  5. * Javascript md5() 函数 用于生成字符串对应的md5值
  6. * @param string string 原始字符串
  7. * @return string 加密后的32位md5字符串
  8. */
  9. function md5(string){
  10. function md5_RotateLeft(lValue, iShiftBits) {
  11. return (lValue<<iShiftBits) | (lValue>>>(32-iShiftBits));
  12. }
  13. function md5_AddUnsigned(lX,lY){
  14. var lX4,lY4,lX8,lY8,lResult;
  15. lX8 = (lX & 0x80000000);
  16. lY8 = (lY & 0x80000000);
  17. lX4 = (lX & 0x40000000);
  18. lY4 = (lY & 0x40000000);
  19. lResult = (lX & 0x3FFFFFFF)+(lY & 0x3FFFFFFF);
  20. if (lX4 & lY4) {
  21. return (lResult ^ 0x80000000 ^ lX8 ^ lY8);
  22. }
  23. if (lX4 | lY4) {
  24. if (lResult & 0x40000000) {
  25. return (lResult ^ 0xC0000000 ^ lX8 ^ lY8);
  26. } else {
  27. return (lResult ^ 0x40000000 ^ lX8 ^ lY8);
  28. }
  29. } else {
  30. return (lResult ^ lX8 ^ lY8);
  31. }
  32. }
  33. function md5_F(x,y,z){
  34. return (x & y) | ((~x) & z);
  35. }
  36. function md5_G(x,y,z){
  37. return (x & z) | (y & (~z));
  38. }
  39. function md5_H(x,y,z){
  40. return (x ^ y ^ z);
  41. }
  42. function md5_I(x,y,z){
  43. return (y ^ (x | (~z)));
  44. }
  45. function md5_FF(a,b,c,d,x,s,ac){
  46. a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_F(b, c, d), x), ac));
  47. return md5_AddUnsigned(md5_RotateLeft(a, s), b);
  48. };
  49. function md5_GG(a,b,c,d,x,s,ac){
  50. a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_G(b, c, d), x), ac));
  51. return md5_AddUnsigned(md5_RotateLeft(a, s), b);
  52. };
  53. function md5_HH(a,b,c,d,x,s,ac){
  54. a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_H(b, c, d), x), ac));
  55. return md5_AddUnsigned(md5_RotateLeft(a, s), b);
  56. };
  57. function md5_II(a,b,c,d,x,s,ac){
  58. a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_I(b, c, d), x), ac));
  59. return md5_AddUnsigned(md5_RotateLeft(a, s), b);
  60. };
  61. function md5_ConvertToWordArray(string) {
  62. var lWordCount;
  63. var lMessageLength = string.length;
  64. var lNumberOfWords_temp1=lMessageLength + 8;
  65. var lNumberOfWords_temp2=(lNumberOfWords_temp1-(lNumberOfWords_temp1 % 64))/64;
  66. var lNumberOfWords = (lNumberOfWords_temp2+1)*16;
  67. var lWordArray=Array(lNumberOfWords-1);
  68. var lBytePosition = 0;
  69. var lByteCount = 0;
  70. while ( lByteCount < lMessageLength ) {
  71. lWordCount = (lByteCount-(lByteCount % 4))/4;
  72. lBytePosition = (lByteCount % 4)*8;
  73. lWordArray[lWordCount] = (lWordArray[lWordCount] | (string.charCodeAt(lByteCount)<<lBytePosition));
  74. lByteCount++;
  75. }
  76. lWordCount = (lByteCount-(lByteCount % 4))/4;
  77. lBytePosition = (lByteCount % 4)*8;
  78. lWordArray[lWordCount] = lWordArray[lWordCount] | (0x80<<lBytePosition);
  79. lWordArray[lNumberOfWords-2] = lMessageLength<<3;
  80. lWordArray[lNumberOfWords-1] = lMessageLength>>>29;
  81. return lWordArray;
  82. };
  83. function md5_WordToHex(lValue){
  84. var WordToHexValue="",WordToHexValue_temp="",lByte,lCount;
  85. for(lCount = 0;lCount<=3;lCount++){
  86. lByte = (lValue>>>(lCount*8)) & 255;
  87. WordToHexValue_temp = "0" + lByte.toString(16);
  88. WordToHexValue = WordToHexValue + WordToHexValue_temp.substr(WordToHexValue_temp.length-2,2);
  89. }
  90. return WordToHexValue;
  91. };
  92. function md5_Utf8Encode(string){
  93. string = string.replace(/\r\n/g,"\n");
  94. var utftext = "";
  95. for (var n = 0; n < string.length; n++) {
  96. var c = string.charCodeAt(n);
  97. if (c < 128) {
  98. utftext += String.fromCharCode(c);
  99. }else if((c > 127) && (c < 2048)) {
  100. utftext += String.fromCharCode((c >> 6) | 192);
  101. utftext += String.fromCharCode((c & 63) | 128);
  102. } else {
  103. utftext += String.fromCharCode((c >> 12) | 224);
  104. utftext += String.fromCharCode(((c >> 6) & 63) | 128);
  105. utftext += String.fromCharCode((c & 63) | 128);
  106. }
  107. }
  108. return utftext;
  109. };
  110. var x=Array();
  111. var k,AA,BB,CC,DD,a,b,c,d;
  112. var S11=7, S12=12, S13=17, S14=22;
  113. var S21=5, S22=9 , S23=14, S24=20;
  114. var S31=4, S32=11, S33=16, S34=23;
  115. var S41=6, S42=10, S43=15, S44=21;
  116. string = md5_Utf8Encode(string);
  117. x = md5_ConvertToWordArray(string);
  118. a = 0x67452301; b = 0xEFCDAB89; c = 0x98BADCFE; d = 0x10325476;
  119. for (k=0;k<x.length;k+=16) {
  120. AA=a; BB=b; CC=c; DD=d;
  121. a=md5_FF(a,b,c,d,x[k+0], S11,0xD76AA478);
  122. d=md5_FF(d,a,b,c,x[k+1], S12,0xE8C7B756);
  123. c=md5_FF(c,d,a,b,x[k+2], S13,0x242070DB);
  124. b=md5_FF(b,c,d,a,x[k+3], S14,0xC1BDCEEE);
  125. a=md5_FF(a,b,c,d,x[k+4], S11,0xF57C0FAF);
  126. d=md5_FF(d,a,b,c,x[k+5], S12,0x4787C62A);
  127. c=md5_FF(c,d,a,b,x[k+6], S13,0xA8304613);
  128. b=md5_FF(b,c,d,a,x[k+7], S14,0xFD469501);
  129. a=md5_FF(a,b,c,d,x[k+8], S11,0x698098D8);
  130. d=md5_FF(d,a,b,c,x[k+9], S12,0x8B44F7AF);
  131. c=md5_FF(c,d,a,b,x[k+10],S13,0xFFFF5BB1);
  132. b=md5_FF(b,c,d,a,x[k+11],S14,0x895CD7BE);
  133. a=md5_FF(a,b,c,d,x[k+12],S11,0x6B901122);
  134. d=md5_FF(d,a,b,c,x[k+13],S12,0xFD987193);
  135. c=md5_FF(c,d,a,b,x[k+14],S13,0xA679438E);
  136. b=md5_FF(b,c,d,a,x[k+15],S14,0x49B40821);
  137. a=md5_GG(a,b,c,d,x[k+1], S21,0xF61E2562);
  138. d=md5_GG(d,a,b,c,x[k+6], S22,0xC040B340);
  139. c=md5_GG(c,d,a,b,x[k+11],S23,0x265E5A51);
  140. b=md5_GG(b,c,d,a,x[k+0], S24,0xE9B6C7AA);
  141. a=md5_GG(a,b,c,d,x[k+5], S21,0xD62F105D);
  142. d=md5_GG(d,a,b,c,x[k+10],S22,0x2441453);
  143. c=md5_GG(c,d,a,b,x[k+15],S23,0xD8A1E681);
  144. b=md5_GG(b,c,d,a,x[k+4], S24,0xE7D3FBC8);
  145. a=md5_GG(a,b,c,d,x[k+9], S21,0x21E1CDE6);
  146. d=md5_GG(d,a,b,c,x[k+14],S22,0xC33707D6);
  147. c=md5_GG(c,d,a,b,x[k+3], S23,0xF4D50D87);
  148. b=md5_GG(b,c,d,a,x[k+8], S24,0x455A14ED);
  149. a=md5_GG(a,b,c,d,x[k+13],S21,0xA9E3E905);
  150. d=md5_GG(d,a,b,c,x[k+2], S22,0xFCEFA3F8);
  151. c=md5_GG(c,d,a,b,x[k+7], S23,0x676F02D9);
  152. b=md5_GG(b,c,d,a,x[k+12],S24,0x8D2A4C8A);
  153. a=md5_HH(a,b,c,d,x[k+5], S31,0xFFFA3942);
  154. d=md5_HH(d,a,b,c,x[k+8], S32,0x8771F681);
  155. c=md5_HH(c,d,a,b,x[k+11],S33,0x6D9D6122);
  156. b=md5_HH(b,c,d,a,x[k+14],S34,0xFDE5380C);
  157. a=md5_HH(a,b,c,d,x[k+1], S31,0xA4BEEA44);
  158. d=md5_HH(d,a,b,c,x[k+4], S32,0x4BDECFA9);
  159. c=md5_HH(c,d,a,b,x[k+7], S33,0xF6BB4B60);
  160. b=md5_HH(b,c,d,a,x[k+10],S34,0xBEBFBC70);
  161. a=md5_HH(a,b,c,d,x[k+13],S31,0x289B7EC6);
  162. d=md5_HH(d,a,b,c,x[k+0], S32,0xEAA127FA);
  163. c=md5_HH(c,d,a,b,x[k+3], S33,0xD4EF3085);
  164. b=md5_HH(b,c,d,a,x[k+6], S34,0x4881D05);
  165. a=md5_HH(a,b,c,d,x[k+9], S31,0xD9D4D039);
  166. d=md5_HH(d,a,b,c,x[k+12],S32,0xE6DB99E5);
  167. c=md5_HH(c,d,a,b,x[k+15],S33,0x1FA27CF8);
  168. b=md5_HH(b,c,d,a,x[k+2], S34,0xC4AC5665);
  169. a=md5_II(a,b,c,d,x[k+0], S41,0xF4292244);
  170. d=md5_II(d,a,b,c,x[k+7], S42,0x432AFF97);
  171. c=md5_II(c,d,a,b,x[k+14],S43,0xAB9423A7);
  172. b=md5_II(b,c,d,a,x[k+5], S44,0xFC93A039);
  173. a=md5_II(a,b,c,d,x[k+12],S41,0x655B59C3);
  174. d=md5_II(d,a,b,c,x[k+3], S42,0x8F0CCC92);
  175. c=md5_II(c,d,a,b,x[k+10],S43,0xFFEFF47D);
  176. b=md5_II(b,c,d,a,x[k+1], S44,0x85845DD1);
  177. a=md5_II(a,b,c,d,x[k+8], S41,0x6FA87E4F);
  178. d=md5_II(d,a,b,c,x[k+15],S42,0xFE2CE6E0);
  179. c=md5_II(c,d,a,b,x[k+6], S43,0xA3014314);
  180. b=md5_II(b,c,d,a,x[k+13],S44,0x4E0811A1);
  181. a=md5_II(a,b,c,d,x[k+4], S41,0xF7537E82);
  182. d=md5_II(d,a,b,c,x[k+11],S42,0xBD3AF235);
  183. c=md5_II(c,d,a,b,x[k+2], S43,0x2AD7D2BB);
  184. b=md5_II(b,c,d,a,x[k+9], S44,0xEB86D391);
  185. a=md5_AddUnsigned(a,AA);
  186. b=md5_AddUnsigned(b,BB);
  187. c=md5_AddUnsigned(c,CC);
  188. d=md5_AddUnsigned(d,DD);
  189. }
  190. return (md5_WordToHex(a)+md5_WordToHex(b)+md5_WordToHex(c)+md5_WordToHex(d)).toLowerCase();
  191. }