crypto.js 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789
  1. let key = ''; //eta
  2. class CryptoJS {
  3. // 3DES加密,CBC/PKCS5Padding
  4. static Des3Encrypt (input,keyVal) {
  5. key=keyVal
  6. let genKey = genkey(key, 0, 24);
  7. return base64encode(des(genKey.key, input, 1, 1, key.substr(0, 8), 1));
  8. }
  9. // 3DES解密,CBC/PKCS5Padding
  10. static Des3Decrypt (input,keyVal) {
  11. key=keyVal
  12. let genKey = genkey(key, 0, 24);
  13. return des(genKey.key, base64decode(input), 0, 1, key.substr(0, 8), 1);
  14. }
  15. // md5
  16. static Md5Encrypt (input) {
  17. return md5(String(input));
  18. }
  19. }
  20. function des (key, message, encrypt, mode, iv, padding) {
  21. if (encrypt) // 如果是加密的话,首先转换编码
  22. { message = unescape(encodeURIComponent(message)); }
  23. // declaring this locally speeds things up a bit
  24. let spfunction1 = new Array(0x1010400, 0, 0x10000, 0x1010404, 0x1010004, 0x10404, 0x4, 0x10000, 0x400, 0x1010400, 0x1010404, 0x400, 0x1000404, 0x1010004, 0x1000000, 0x4, 0x404, 0x1000400, 0x1000400, 0x10400, 0x10400, 0x1010000, 0x1010000, 0x1000404, 0x10004, 0x1000004, 0x1000004, 0x10004, 0, 0x404, 0x10404, 0x1000000, 0x10000, 0x1010404, 0x4, 0x1010000, 0x1010400, 0x1000000, 0x1000000, 0x400, 0x1010004, 0x10000, 0x10400, 0x1000004, 0x400, 0x4, 0x1000404, 0x10404, 0x1010404, 0x10004, 0x1010000, 0x1000404, 0x1000004, 0x404, 0x10404, 0x1010400, 0x404, 0x1000400, 0x1000400, 0, 0x10004, 0x10400, 0, 0x1010004);
  25. let spfunction2 = new Array(-0x7fef7fe0, -0x7fff8000, 0x8000, 0x108020, 0x100000, 0x20, -0x7fefffe0, -0x7fff7fe0, -0x7fffffe0, -0x7fef7fe0, -0x7fef8000, -0x80000000, -0x7fff8000, 0x100000, 0x20, -0x7fefffe0, 0x108000, 0x100020, -0x7fff7fe0, 0, -0x80000000, 0x8000, 0x108020, -0x7ff00000, 0x100020, -0x7fffffe0, 0, 0x108000, 0x8020, -0x7fef8000, -0x7ff00000, 0x8020, 0, 0x108020, -0x7fefffe0, 0x100000, -0x7fff7fe0, -0x7ff00000, -0x7fef8000, 0x8000, -0x7ff00000, -0x7fff8000, 0x20, -0x7fef7fe0, 0x108020, 0x20, 0x8000, -0x80000000, 0x8020, -0x7fef8000, 0x100000, -0x7fffffe0, 0x100020, -0x7fff7fe0, -0x7fffffe0, 0x100020, 0x108000, 0, -0x7fff8000, 0x8020, -0x80000000, -0x7fefffe0, -0x7fef7fe0, 0x108000);
  26. let spfunction3 = new Array(0x208, 0x8020200, 0, 0x8020008, 0x8000200, 0, 0x20208, 0x8000200, 0x20008, 0x8000008, 0x8000008, 0x20000, 0x8020208, 0x20008, 0x8020000, 0x208, 0x8000000, 0x8, 0x8020200, 0x200, 0x20200, 0x8020000, 0x8020008, 0x20208, 0x8000208, 0x20200, 0x20000, 0x8000208, 0x8, 0x8020208, 0x200, 0x8000000, 0x8020200, 0x8000000, 0x20008, 0x208, 0x20000, 0x8020200, 0x8000200, 0, 0x200, 0x20008, 0x8020208, 0x8000200, 0x8000008, 0x200, 0, 0x8020008, 0x8000208, 0x20000, 0x8000000, 0x8020208, 0x8, 0x20208, 0x20200, 0x8000008, 0x8020000, 0x8000208, 0x208, 0x8020000, 0x20208, 0x8, 0x8020008, 0x20200);
  27. let spfunction4 = new Array(0x802001, 0x2081, 0x2081, 0x80, 0x802080, 0x800081, 0x800001, 0x2001, 0, 0x802000, 0x802000, 0x802081, 0x81, 0, 0x800080, 0x800001, 0x1, 0x2000, 0x800000, 0x802001, 0x80, 0x800000, 0x2001, 0x2080, 0x800081, 0x1, 0x2080, 0x800080, 0x2000, 0x802080, 0x802081, 0x81, 0x800080, 0x800001, 0x802000, 0x802081, 0x81, 0, 0, 0x802000, 0x2080, 0x800080, 0x800081, 0x1, 0x802001, 0x2081, 0x2081, 0x80, 0x802081, 0x81, 0x1, 0x2000, 0x800001, 0x2001, 0x802080, 0x800081, 0x2001, 0x2080, 0x800000, 0x802001, 0x80, 0x800000, 0x2000, 0x802080);
  28. let spfunction5 = new Array(0x100, 0x2080100, 0x2080000, 0x42000100, 0x80000, 0x100, 0x40000000, 0x2080000, 0x40080100, 0x80000, 0x2000100, 0x40080100, 0x42000100, 0x42080000, 0x80100, 0x40000000, 0x2000000, 0x40080000, 0x40080000, 0, 0x40000100, 0x42080100, 0x42080100, 0x2000100, 0x42080000, 0x40000100, 0, 0x42000000, 0x2080100, 0x2000000, 0x42000000, 0x80100, 0x80000, 0x42000100, 0x100, 0x2000000, 0x40000000, 0x2080000, 0x42000100, 0x40080100, 0x2000100, 0x40000000, 0x42080000, 0x2080100, 0x40080100, 0x100, 0x2000000, 0x42080000, 0x42080100, 0x80100, 0x42000000, 0x42080100, 0x2080000, 0, 0x40080000, 0x42000000, 0x80100, 0x2000100, 0x40000100, 0x80000, 0, 0x40080000, 0x2080100, 0x40000100);
  29. let spfunction6 = new Array(0x20000010, 0x20400000, 0x4000, 0x20404010, 0x20400000, 0x10, 0x20404010, 0x400000, 0x20004000, 0x404010, 0x400000, 0x20000010, 0x400010, 0x20004000, 0x20000000, 0x4010, 0, 0x400010, 0x20004010, 0x4000, 0x404000, 0x20004010, 0x10, 0x20400010, 0x20400010, 0, 0x404010, 0x20404000, 0x4010, 0x404000, 0x20404000, 0x20000000, 0x20004000, 0x10, 0x20400010, 0x404000, 0x20404010, 0x400000, 0x4010, 0x20000010, 0x400000, 0x20004000, 0x20000000, 0x4010, 0x20000010, 0x20404010, 0x404000, 0x20400000, 0x404010, 0x20404000, 0, 0x20400010, 0x10, 0x4000, 0x20400000, 0x404010, 0x4000, 0x400010, 0x20004010, 0, 0x20404000, 0x20000000, 0x400010, 0x20004010);
  30. let spfunction7 = new Array(0x200000, 0x4200002, 0x4000802, 0, 0x800, 0x4000802, 0x200802, 0x4200800, 0x4200802, 0x200000, 0, 0x4000002, 0x2, 0x4000000, 0x4200002, 0x802, 0x4000800, 0x200802, 0x200002, 0x4000800, 0x4000002, 0x4200000, 0x4200800, 0x200002, 0x4200000, 0x800, 0x802, 0x4200802, 0x200800, 0x2, 0x4000000, 0x200800, 0x4000000, 0x200800, 0x200000, 0x4000802, 0x4000802, 0x4200002, 0x4200002, 0x2, 0x200002, 0x4000000, 0x4000800, 0x200000, 0x4200800, 0x802, 0x200802, 0x4200800, 0x802, 0x4000002, 0x4200802, 0x4200000, 0x200800, 0, 0x2, 0x4200802, 0, 0x200802, 0x4200000, 0x800, 0x4000002, 0x4000800, 0x800, 0x200002);
  31. let spfunction8 = new Array(0x10001040, 0x1000, 0x40000, 0x10041040, 0x10000000, 0x10001040, 0x40, 0x10000000, 0x40040, 0x10040000, 0x10041040, 0x41000, 0x10041000, 0x41040, 0x1000, 0x40, 0x10040000, 0x10000040, 0x10001000, 0x1040, 0x41000, 0x40040, 0x10040040, 0x10041000, 0x1040, 0, 0, 0x10040040, 0x10000040, 0x10001000, 0x41040, 0x40000, 0x41040, 0x40000, 0x10041000, 0x1000, 0x40, 0x10040040, 0x1000, 0x41040, 0x10001000, 0x40, 0x10000040, 0x10040000, 0x10040040, 0x10000000, 0x40000, 0x10001040, 0, 0x10041040, 0x40040, 0x10000040, 0x10040000, 0x10001000, 0x10001040, 0, 0x10041040, 0x41000, 0x41000, 0x1040, 0x1040, 0x40040, 0x10000000, 0x10041000);
  32. // create the 16 or 48 subkeys we will need
  33. let keys = des_createKeys(key);
  34. let m = 0, i, j, temp, temp2, right1, right2, left, right, looping;
  35. let cbcleft, cbcleft2, cbcright, cbcright2;
  36. let endloop, loopinc;
  37. var len = message.length;
  38. let chunk = 0;
  39. // set up the loops for single and triple des
  40. let iterations = keys.length === 32 ? 3 : 9; // single or triple des
  41. if (iterations === 3) { looping = encrypt ? new Array(0, 32, 2) : new Array(30, -2, -2); } else { looping = encrypt ? new Array(0, 32, 2, 62, 30, -2, 64, 96, 2) : new Array(94, 62, -2, 32, 64, 2, 30, -2, -2); }
  42. // pad the message depending on the padding parameter
  43. if (padding === 2) message += ' '; // pad the message with spaces
  44. else if (padding === 1) {
  45. if (encrypt) {
  46. temp = 8 - (len % 8);
  47. message += String.fromCharCode(temp, temp, temp, temp, temp, temp, temp, temp);
  48. if (temp === 8) len += 8;
  49. }
  50. } // PKCS7 padding
  51. else if (!padding) message += '\0\0\0\0\0\0\0\0'; // pad the message out with null bytes
  52. // store the result here
  53. let result = '';
  54. let tempresult = '';
  55. if (mode === 1) { // CBC mode
  56. cbcleft = (iv.charCodeAt(m++) << 24) | (iv.charCodeAt(m++) << 16) | (iv.charCodeAt(m++) << 8) | iv.charCodeAt(m++);
  57. cbcright = (iv.charCodeAt(m++) << 24) | (iv.charCodeAt(m++) << 16) | (iv.charCodeAt(m++) << 8) | iv.charCodeAt(m++);
  58. m = 0;
  59. }
  60. // loop through each 64 bit chunk of the message
  61. while (m < len) {
  62. left = (message.charCodeAt(m++) << 24) | (message.charCodeAt(m++) << 16) | (message.charCodeAt(m++) << 8) | message.charCodeAt(m++);
  63. right = (message.charCodeAt(m++) << 24) | (message.charCodeAt(m++) << 16) | (message.charCodeAt(m++) << 8) | message.charCodeAt(m++);
  64. // for Cipher Block Chaining mode, xor the message with the previous result
  65. if (mode === 1) {
  66. if (encrypt) {
  67. left ^= cbcleft;
  68. right ^= cbcright;
  69. } else {
  70. cbcleft2 = cbcleft;
  71. cbcright2 = cbcright;
  72. cbcleft = left;
  73. cbcright = right;
  74. }
  75. }
  76. // first each 64 but chunk of the message must be permuted according to IP
  77. temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
  78. right ^= temp;
  79. left ^= (temp << 4);
  80. temp = ((left >>> 16) ^ right) & 0x0000ffff;
  81. right ^= temp;
  82. left ^= (temp << 16);
  83. temp = ((right >>> 2) ^ left) & 0x33333333;
  84. left ^= temp;
  85. right ^= (temp << 2);
  86. temp = ((right >>> 8) ^ left) & 0x00ff00ff;
  87. left ^= temp;
  88. right ^= (temp << 8);
  89. temp = ((left >>> 1) ^ right) & 0x55555555;
  90. right ^= temp;
  91. left ^= (temp << 1);
  92. left = ((left << 1) | (left >>> 31));
  93. right = ((right << 1) | (right >>> 31));
  94. // do this either 1 or 3 times for each chunk of the message
  95. for (j = 0; j < iterations; j += 3) {
  96. endloop = looping[j + 1];
  97. loopinc = looping[j + 2];
  98. // now go through and perform the encryption or decryption
  99. for (i = looping[j]; i !== endloop; i += loopinc) { // for efficiency
  100. right1 = right ^ keys[i];
  101. right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];
  102. // the result is attained by passing these bytes through the S selection functions
  103. temp = left;
  104. left = right;
  105. right = temp ^ (spfunction2[(right1 >>> 24) & 0x3f] | spfunction4[(right1 >>> 16) & 0x3f] |
  106. spfunction6[(right1 >>> 8) & 0x3f] | spfunction8[right1 & 0x3f] |
  107. spfunction1[(right2 >>> 24) & 0x3f] | spfunction3[(right2 >>> 16) & 0x3f] |
  108. spfunction5[(right2 >>> 8) & 0x3f] | spfunction7[right2 & 0x3f]);
  109. }
  110. temp = left;
  111. left = right;
  112. right = temp; // unreverse left and right
  113. } // for either 1 or 3 iterations
  114. // move then each one bit to the right
  115. left = ((left >>> 1) | (left << 31));
  116. right = ((right >>> 1) | (right << 31));
  117. // now perform IP-1, which is IP in the opposite direction
  118. temp = ((left >>> 1) ^ right) & 0x55555555;
  119. right ^= temp;
  120. left ^= (temp << 1);
  121. temp = ((right >>> 8) ^ left) & 0x00ff00ff;
  122. left ^= temp;
  123. right ^= (temp << 8);
  124. temp = ((right >>> 2) ^ left) & 0x33333333;
  125. left ^= temp;
  126. right ^= (temp << 2);
  127. temp = ((left >>> 16) ^ right) & 0x0000ffff;
  128. right ^= temp;
  129. left ^= (temp << 16);
  130. temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
  131. right ^= temp;
  132. left ^= (temp << 4);
  133. // for Cipher Block Chaining mode, xor the message with the previous result
  134. if (mode === 1) {
  135. if (encrypt) {
  136. cbcleft = left;
  137. cbcright = right;
  138. } else {
  139. left ^= cbcleft2;
  140. right ^= cbcright2;
  141. }
  142. }
  143. tempresult += String.fromCharCode((left >>> 24), ((left >>> 16) & 0xff), ((left >>> 8) & 0xff), (left & 0xff), (right >>> 24), ((right >>> 16) & 0xff), ((right >>> 8) & 0xff), (right & 0xff));
  144. chunk += 8;
  145. if (chunk === 512) {
  146. result += tempresult;
  147. tempresult = '';
  148. chunk = 0;
  149. }
  150. } // for every 8 characters, or 64 bits in the message
  151. // return the result as an array
  152. result += tempresult;
  153. result = result.replace(/\0*$/g, '');
  154. if (!encrypt) { // 如果是解密的话,解密结束后对PKCS7 padding进行解码,并转换成utf-8编码
  155. if (padding === 1) { // PKCS7 padding解码
  156. var len = result.length, paddingChars = 0;
  157. len && (paddingChars = result.charCodeAt(len - 1));
  158. (paddingChars <= 8) && (result = result.substring(0, len - paddingChars));
  159. }
  160. // 转换成UTF-8编码
  161. result = decodeURIComponent(escape(result));
  162. }
  163. return result;
  164. } // end of des
  165. // des_createKeys
  166. // this takes as input a 64 bit key (even though only 56 bits are used)
  167. // as an array of 2 integers, and returns 16 48 bit keys
  168. function des_createKeys (key) {
  169. // declaring this locally speeds things up a bit
  170. let pc2bytes0 = new Array(0, 0x4, 0x20000000, 0x20000004, 0x10000, 0x10004, 0x20010000, 0x20010004, 0x200, 0x204, 0x20000200, 0x20000204, 0x10200, 0x10204, 0x20010200, 0x20010204);
  171. let pc2bytes1 = new Array(0, 0x1, 0x100000, 0x100001, 0x4000000, 0x4000001, 0x4100000, 0x4100001, 0x100, 0x101, 0x100100, 0x100101, 0x4000100, 0x4000101, 0x4100100, 0x4100101);
  172. let pc2bytes2 = new Array(0, 0x8, 0x800, 0x808, 0x1000000, 0x1000008, 0x1000800, 0x1000808, 0, 0x8, 0x800, 0x808, 0x1000000, 0x1000008, 0x1000800, 0x1000808);
  173. let pc2bytes3 = new Array(0, 0x200000, 0x8000000, 0x8200000, 0x2000, 0x202000, 0x8002000, 0x8202000, 0x20000, 0x220000, 0x8020000, 0x8220000, 0x22000, 0x222000, 0x8022000, 0x8222000);
  174. let pc2bytes4 = new Array(0, 0x40000, 0x10, 0x40010, 0, 0x40000, 0x10, 0x40010, 0x1000, 0x41000, 0x1010, 0x41010, 0x1000, 0x41000, 0x1010, 0x41010);
  175. let pc2bytes5 = new Array(0, 0x400, 0x20, 0x420, 0, 0x400, 0x20, 0x420, 0x2000000, 0x2000400, 0x2000020, 0x2000420, 0x2000000, 0x2000400, 0x2000020, 0x2000420);
  176. let pc2bytes6 = new Array(0, 0x10000000, 0x80000, 0x10080000, 0x2, 0x10000002, 0x80002, 0x10080002, 0, 0x10000000, 0x80000, 0x10080000, 0x2, 0x10000002, 0x80002, 0x10080002);
  177. let pc2bytes7 = new Array(0, 0x10000, 0x800, 0x10800, 0x20000000, 0x20010000, 0x20000800, 0x20010800, 0x20000, 0x30000, 0x20800, 0x30800, 0x20020000, 0x20030000, 0x20020800, 0x20030800);
  178. let pc2bytes8 = new Array(0, 0x40000, 0, 0x40000, 0x2, 0x40002, 0x2, 0x40002, 0x2000000, 0x2040000, 0x2000000, 0x2040000, 0x2000002, 0x2040002, 0x2000002, 0x2040002);
  179. let pc2bytes9 = new Array(0, 0x10000000, 0x8, 0x10000008, 0, 0x10000000, 0x8, 0x10000008, 0x400, 0x10000400, 0x408, 0x10000408, 0x400, 0x10000400, 0x408, 0x10000408);
  180. let pc2bytes10 = new Array(0, 0x20, 0, 0x20, 0x100000, 0x100020, 0x100000, 0x100020, 0x2000, 0x2020, 0x2000, 0x2020, 0x102000, 0x102020, 0x102000, 0x102020);
  181. let pc2bytes11 = new Array(0, 0x1000000, 0x200, 0x1000200, 0x200000, 0x1200000, 0x200200, 0x1200200, 0x4000000, 0x5000000, 0x4000200, 0x5000200, 0x4200000, 0x5200000, 0x4200200, 0x5200200);
  182. let pc2bytes12 = new Array(0, 0x1000, 0x8000000, 0x8001000, 0x80000, 0x81000, 0x8080000, 0x8081000, 0x10, 0x1010, 0x8000010, 0x8001010, 0x80010, 0x81010, 0x8080010, 0x8081010);
  183. let pc2bytes13 = new Array(0, 0x4, 0x100, 0x104, 0, 0x4, 0x100, 0x104, 0x1, 0x5, 0x101, 0x105, 0x1, 0x5, 0x101, 0x105);
  184. // how many iterations (1 for des, 3 for triple des)
  185. let iterations = key.length > 8 ? 3 : 1; // changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys
  186. // stores the return keys
  187. let keys = new Array(32 * iterations);
  188. // now define the left shifts which need to be done
  189. let shifts = new Array(0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0);
  190. // other variables
  191. let lefttemp, righttemp, m = 0, n = 0, temp;
  192. for (let j = 0; j < iterations; j++) { // either 1 or 3 iterations
  193. let left = (key.charCodeAt(m++) << 24) | (key.charCodeAt(m++) << 16) | (key.charCodeAt(m++) << 8) | key.charCodeAt(m++);
  194. let right = (key.charCodeAt(m++) << 24) | (key.charCodeAt(m++) << 16) | (key.charCodeAt(m++) << 8) | key.charCodeAt(m++);
  195. temp = ((left >>> 4) ^ right) & 0x0f0f0f0f;
  196. right ^= temp;
  197. left ^= (temp << 4);
  198. temp = ((right >>> -16) ^ left) & 0x0000ffff;
  199. left ^= temp;
  200. right ^= (temp << -16);
  201. temp = ((left >>> 2) ^ right) & 0x33333333;
  202. right ^= temp;
  203. left ^= (temp << 2);
  204. temp = ((right >>> -16) ^ left) & 0x0000ffff;
  205. left ^= temp;
  206. right ^= (temp << -16);
  207. temp = ((left >>> 1) ^ right) & 0x55555555;
  208. right ^= temp;
  209. left ^= (temp << 1);
  210. temp = ((right >>> 8) ^ left) & 0x00ff00ff;
  211. left ^= temp;
  212. right ^= (temp << 8);
  213. temp = ((left >>> 1) ^ right) & 0x55555555;
  214. right ^= temp;
  215. left ^= (temp << 1);
  216. // the right side needs to be shifted and to get the last four bits of the left side
  217. temp = (left << 8) | ((right >>> 20) & 0x000000f0);
  218. // left needs to be put upside down
  219. left = (right << 24) | ((right << 8) & 0xff0000) | ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0);
  220. right = temp;
  221. // now go through and perform these shifts on the left and right keys
  222. for (let i = 0; i < shifts.length; i++) {
  223. // shift the keys either one or two bits to the left
  224. if (shifts[i]) {
  225. left = (left << 2) | (left >>> 26);
  226. right = (right << 2) | (right >>> 26);
  227. } else {
  228. left = (left << 1) | (left >>> 27);
  229. right = (right << 1) | (right >>> 27);
  230. }
  231. left &= -0xf;
  232. right &= -0xf;
  233. // now apply PC-2, in such a way that E is easier when encrypting or decrypting
  234. // this conversion will look like PC-2 except only the last 6 bits of each byte are used
  235. // rather than 48 consecutive bits and the order of lines will be according to
  236. // how the S selection functions will be applied: S2, S4, S6, S8, S1, S3, S5, S7
  237. lefttemp = pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] |
  238. pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf] |
  239. pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] |
  240. pc2bytes6[(left >>> 4) & 0xf];
  241. righttemp = pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] |
  242. pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf] |
  243. pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |
  244. pc2bytes13[(right >>> 4) & 0xf];
  245. temp = ((righttemp >>> 16) ^ lefttemp) & 0x0000ffff;
  246. keys[n++] = lefttemp ^ temp;
  247. keys[n++] = righttemp ^ (temp << 16);
  248. }
  249. } // for each iterations
  250. // return the keys we've created
  251. return keys;
  252. } // end of des_createKeys
  253. function genkey (key, start, end) {
  254. // 8 byte / 64 bit Key (DES) or 192 bit Key
  255. return { key: pad(key.slice(start, end)), vector: 1 };
  256. }
  257. function pad (key) {
  258. for (let i = key.length; i < 24; i++) {
  259. key += '0';
  260. }
  261. return key;
  262. }
  263. let BASE64_MAPPING = [
  264. 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
  265. 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
  266. 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X',
  267. 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
  268. 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
  269. 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
  270. 'w', 'x', 'y', 'z', '0', '1', '2', '3',
  271. '4', '5', '6', '7', '8', '9', '+', '/'
  272. ];
  273. /**
  274. *ascii convert to binary
  275. */
  276. let _toBinary = function (ascii) {
  277. let binary = new Array();
  278. while (ascii > 0) {
  279. let b = ascii % 2;
  280. ascii = Math.floor(ascii / 2);
  281. binary.push(b);
  282. }
  283. /*
  284. var len = binary.length;
  285. if(6-len > 0){
  286. for(var i = 6-len ; i > 0 ; --i){
  287. binary.push(0);
  288. }
  289. } */
  290. binary.reverse();
  291. return binary;
  292. };
  293. /**
  294. *binary convert to decimal
  295. */
  296. let _toDecimal = function (binary) {
  297. let dec = 0;
  298. let p = 0;
  299. for (let i = binary.length - 1; i >= 0; --i) {
  300. let b = binary[i];
  301. if (b === 1) {
  302. dec += Math.pow(2, p);
  303. }
  304. ++p;
  305. }
  306. return dec;
  307. };
  308. /**
  309. *unicode convert to utf-8
  310. */
  311. let _toUTF8Binary = function (c, binaryArray) {
  312. let mustLen = (8 - (c + 1)) + ((c - 1) * 6);
  313. let fatLen = binaryArray.length;
  314. let diff = mustLen - fatLen;
  315. while (--diff >= 0) {
  316. binaryArray.unshift(0);
  317. }
  318. let binary = [];
  319. let _c = c;
  320. while (--_c >= 0) {
  321. binary.push(1);
  322. }
  323. binary.push(0);
  324. let i = 0, len = 8 - (c + 1);
  325. for (; i < len; ++i) {
  326. binary.push(binaryArray[i]);
  327. }
  328. for (let j = 0; j < c - 1; ++j) {
  329. binary.push(1);
  330. binary.push(0);
  331. let sum = 6;
  332. while (--sum >= 0) {
  333. binary.push(binaryArray[i++]);
  334. }
  335. }
  336. return binary;
  337. };
  338. let BASE64 = {
  339. /**
  340. *BASE64 Encode
  341. */
  342. encoder: function (str) {
  343. let base64_Index = [];
  344. let binaryArray = [];
  345. for (var i = 0, len = str.length; i < len; ++i) {
  346. let unicode = str.charCodeAt(i);
  347. let _tmpBinary = _toBinary(unicode);
  348. if (unicode < 0x80) {
  349. let _tmpdiff = 8 - _tmpBinary.length;
  350. while (--_tmpdiff >= 0) {
  351. _tmpBinary.unshift(0);
  352. }
  353. binaryArray = binaryArray.concat(_tmpBinary);
  354. } else if (unicode >= 0x80 && unicode <= 0x7FF) {
  355. binaryArray = binaryArray.concat(_toUTF8Binary(2, _tmpBinary));
  356. } else if (unicode >= 0x800 && unicode <= 0xFFFF) { // UTF-8 3byte
  357. binaryArray = binaryArray.concat(_toUTF8Binary(3, _tmpBinary));
  358. } else if (unicode >= 0x10000 && unicode <= 0x1FFFFF) { // UTF-8 4byte
  359. binaryArray = binaryArray.concat(_toUTF8Binary(4, _tmpBinary));
  360. } else if (unicode >= 0x200000 && unicode <= 0x3FFFFFF) { // UTF-8 5byte
  361. binaryArray = binaryArray.concat(_toUTF8Binary(5, _tmpBinary));
  362. } else if (unicode >= 4000000 && unicode <= 0x7FFFFFFF) { // UTF-8 6byte
  363. binaryArray = binaryArray.concat(_toUTF8Binary(6, _tmpBinary));
  364. }
  365. }
  366. let extra_Zero_Count = 0;
  367. for (var i = 0, len = binaryArray.length; i < len; i += 6) {
  368. let diff = (i + 6) - len;
  369. if (diff === 2) {
  370. extra_Zero_Count = 2;
  371. } else if (diff === 4) {
  372. extra_Zero_Count = 4;
  373. }
  374. // if(extra_Zero_Count > 0){
  375. // len += extra_Zero_Count+1;
  376. // }
  377. let _tmpExtra_Zero_Count = extra_Zero_Count;
  378. while (--_tmpExtra_Zero_Count >= 0) {
  379. binaryArray.push(0);
  380. }
  381. base64_Index.push(_toDecimal(binaryArray.slice(i, i + 6)));
  382. }
  383. let base64 = '';
  384. for (var i = 0, len = base64_Index.length; i < len; ++i) {
  385. base64 += BASE64_MAPPING[base64_Index[i]];
  386. }
  387. for (var i = 0, len = extra_Zero_Count / 2; i < len; ++i) {
  388. base64 += '=';
  389. }
  390. return base64;
  391. },
  392. /**
  393. *BASE64 Decode for UTF-8
  394. */
  395. decoder: function (_base64Str) {
  396. let _len = _base64Str.length;
  397. let extra_Zero_Count = 0;
  398. /**
  399. *计算在进行BASE64编码的时候,补了几个0
  400. */
  401. if (_base64Str.charAt(_len - 1) === '=') {
  402. // alert(_base64Str.charAt(_len-1));
  403. // alert(_base64Str.charAt(_len-2));
  404. if (_base64Str.charAt(_len - 2) === '=') { // 两个等号说明补了4个0
  405. extra_Zero_Count = 4;
  406. _base64Str = _base64Str.substring(0, _len - 2);
  407. } else { // 一个等号说明补了2个0
  408. extra_Zero_Count = 2;
  409. _base64Str = _base64Str.substring(0, _len - 1);
  410. }
  411. }
  412. let binaryArray = [];
  413. for (var i = 0, len = _base64Str.length; i < len; ++i) {
  414. let c = _base64Str.charAt(i);
  415. for (let j = 0, size = BASE64_MAPPING.length; j < size; ++j) {
  416. if (c === BASE64_MAPPING[j]) {
  417. let _tmp = _toBinary(j);
  418. /* 不足6位的补0 */
  419. let _tmpLen = _tmp.length;
  420. if (6 - _tmpLen > 0) {
  421. for (let k = 6 - _tmpLen; k > 0; --k) {
  422. _tmp.unshift(0);
  423. }
  424. }
  425. binaryArray = binaryArray.concat(_tmp);
  426. break;
  427. }
  428. }
  429. }
  430. if (extra_Zero_Count > 0) {
  431. binaryArray = binaryArray.slice(0, binaryArray.length - extra_Zero_Count);
  432. }
  433. let unicode = [];
  434. let unicodeBinary = [];
  435. for (var i = 0, len = binaryArray.length; i < len;) {
  436. if (binaryArray[i] === 0) {
  437. unicode = unicode.concat(_toDecimal(binaryArray.slice(i, i + 8)));
  438. i += 8;
  439. } else {
  440. let sum = 0;
  441. while (i < len) {
  442. if (binaryArray[i] === 1) {
  443. ++sum;
  444. } else {
  445. break;
  446. }
  447. ++i;
  448. }
  449. unicodeBinary = unicodeBinary.concat(binaryArray.slice(i + 1, i + 8 - sum));
  450. i += 8 - sum;
  451. while (sum > 1) {
  452. unicodeBinary = unicodeBinary.concat(binaryArray.slice(i + 2, i + 8));
  453. i += 8;
  454. --sum;
  455. }
  456. unicode = unicode.concat(_toDecimal(unicodeBinary));
  457. unicodeBinary = [];
  458. }
  459. }
  460. // ---------直接转换为结果
  461. let strResult = '';
  462. for (var i = 0, len = unicode.length; i < len; ++i) {
  463. strResult += String.fromCharCode(unicode[i]);
  464. }
  465. return strResult;
  466. }
  467. };
  468. let rotateLeft = function (lValue, iShiftBits) {
  469. return (lValue << iShiftBits) | (lValue >>> (32 - iShiftBits));
  470. };
  471. let addUnsigned = function (lX, lY) {
  472. let lX4, lY4, lX8, lY8, lResult;
  473. lX8 = (lX & 0x80000000);
  474. lY8 = (lY & 0x80000000);
  475. lX4 = (lX & 0x40000000);
  476. lY4 = (lY & 0x40000000);
  477. lResult = (lX & 0x3FFFFFFF) + (lY & 0x3FFFFFFF);
  478. if (lX4 & lY4) return (lResult ^ 0x80000000 ^ lX8 ^ lY8);
  479. if (lX4 | lY4) {
  480. if (lResult & 0x40000000) return (lResult ^ 0xC0000000 ^ lX8 ^ lY8);
  481. else return (lResult ^ 0x40000000 ^ lX8 ^ lY8);
  482. } else {
  483. return (lResult ^ lX8 ^ lY8);
  484. }
  485. };
  486. let F = function (x, y, z) {
  487. return (x & y) | ((~x) & z);
  488. };
  489. let G = function (x, y, z) {
  490. return (x & z) | (y & (~z));
  491. };
  492. let H = function (x, y, z) {
  493. return (x ^ y ^ z);
  494. };
  495. let I = function (x, y, z) {
  496. return (y ^ (x | (~z)));
  497. };
  498. let FF = function (a, b, c, d, x, s, ac) {
  499. a = addUnsigned(a, addUnsigned(addUnsigned(F(b, c, d), x), ac));
  500. return addUnsigned(rotateLeft(a, s), b);
  501. };
  502. let GG = function (a, b, c, d, x, s, ac) {
  503. a = addUnsigned(a, addUnsigned(addUnsigned(G(b, c, d), x), ac));
  504. return addUnsigned(rotateLeft(a, s), b);
  505. };
  506. let HH = function (a, b, c, d, x, s, ac) {
  507. a = addUnsigned(a, addUnsigned(addUnsigned(H(b, c, d), x), ac));
  508. return addUnsigned(rotateLeft(a, s), b);
  509. };
  510. let II = function (a, b, c, d, x, s, ac) {
  511. a = addUnsigned(a, addUnsigned(addUnsigned(I(b, c, d), x), ac));
  512. return addUnsigned(rotateLeft(a, s), b);
  513. };
  514. let convertToWordArray = function (string) {
  515. let lWordCount;
  516. let lMessageLength = string.length;
  517. let lNumberOfWordsTempOne = lMessageLength + 8;
  518. let lNumberOfWordsTempTwo = (lNumberOfWordsTempOne - (lNumberOfWordsTempOne % 64)) / 64;
  519. let lNumberOfWords = (lNumberOfWordsTempTwo + 1) * 16;
  520. let lWordArray = Array(lNumberOfWords - 1);
  521. let lBytePosition = 0;
  522. let lByteCount = 0;
  523. while (lByteCount < lMessageLength) {
  524. lWordCount = (lByteCount - (lByteCount % 4)) / 4;
  525. lBytePosition = (lByteCount % 4) * 8;
  526. lWordArray[lWordCount] = (lWordArray[lWordCount] | (string.charCodeAt(lByteCount) << lBytePosition));
  527. lByteCount++;
  528. }
  529. lWordCount = (lByteCount - (lByteCount % 4)) / 4;
  530. lBytePosition = (lByteCount % 4) * 8;
  531. lWordArray[lWordCount] = lWordArray[lWordCount] | (0x80 << lBytePosition);
  532. lWordArray[lNumberOfWords - 2] = lMessageLength << 3;
  533. lWordArray[lNumberOfWords - 1] = lMessageLength >>> 29;
  534. return lWordArray;
  535. };
  536. let wordToHex = function (lValue) {
  537. let WordToHexValue = '', WordToHexValueTemp = '', lByte, lCount;
  538. for (lCount = 0; lCount <= 3; lCount++) {
  539. lByte = (lValue >>> (lCount * 8)) & 255;
  540. WordToHexValueTemp = '0' + lByte.toString(16);
  541. WordToHexValue = WordToHexValue + WordToHexValueTemp.substr(WordToHexValueTemp.length - 2, 2);
  542. }
  543. return WordToHexValue;
  544. };
  545. let uTF8Encode = function (str) {
  546. str = str.replace(/\x0d\x0a/g, '\x0a');
  547. let output = '';
  548. for (let n = 0; n < str.length; n++) {
  549. let c = str.charCodeAt(n);
  550. if (c < 128) {
  551. output += String.fromCharCode(c);
  552. } else if ((c > 127) && (c < 2048)) {
  553. output += String.fromCharCode((c >> 6) | 192);
  554. output += String.fromCharCode((c & 63) | 128);
  555. } else {
  556. output += String.fromCharCode((c >> 12) | 224);
  557. output += String.fromCharCode(((c >> 6) & 63) | 128);
  558. output += String.fromCharCode((c & 63) | 128);
  559. }
  560. }
  561. return output;
  562. };
  563. var md5 = function (string) {
  564. let x = Array();
  565. let k, AA, BB, CC, DD, a, b, c, d;
  566. let S11 = 7, S12 = 12, S13 = 17, S14 = 22;
  567. let S21 = 5, S22 = 9, S23 = 14, S24 = 20;
  568. let S31 = 4, S32 = 11, S33 = 16, S34 = 23;
  569. let S41 = 6, S42 = 10, S43 = 15, S44 = 21;
  570. string = uTF8Encode(string);
  571. x = convertToWordArray(string);
  572. a = 0x67452301;
  573. b = 0xEFCDAB89;
  574. c = 0x98BADCFE;
  575. d = 0x10325476;
  576. for (k = 0; k < x.length; k += 16) {
  577. AA = a;
  578. BB = b;
  579. CC = c;
  580. DD = d;
  581. a = FF(a, b, c, d, x[k + 0], S11, 0xD76AA478);
  582. d = FF(d, a, b, c, x[k + 1], S12, 0xE8C7B756);
  583. c = FF(c, d, a, b, x[k + 2], S13, 0x242070DB);
  584. b = FF(b, c, d, a, x[k + 3], S14, 0xC1BDCEEE);
  585. a = FF(a, b, c, d, x[k + 4], S11, 0xF57C0FAF);
  586. d = FF(d, a, b, c, x[k + 5], S12, 0x4787C62A);
  587. c = FF(c, d, a, b, x[k + 6], S13, 0xA8304613);
  588. b = FF(b, c, d, a, x[k + 7], S14, 0xFD469501);
  589. a = FF(a, b, c, d, x[k + 8], S11, 0x698098D8);
  590. d = FF(d, a, b, c, x[k + 9], S12, 0x8B44F7AF);
  591. c = FF(c, d, a, b, x[k + 10], S13, 0xFFFF5BB1);
  592. b = FF(b, c, d, a, x[k + 11], S14, 0x895CD7BE);
  593. a = FF(a, b, c, d, x[k + 12], S11, 0x6B901122);
  594. d = FF(d, a, b, c, x[k + 13], S12, 0xFD987193);
  595. c = FF(c, d, a, b, x[k + 14], S13, 0xA679438E);
  596. b = FF(b, c, d, a, x[k + 15], S14, 0x49B40821);
  597. a = GG(a, b, c, d, x[k + 1], S21, 0xF61E2562);
  598. d = GG(d, a, b, c, x[k + 6], S22, 0xC040B340);
  599. c = GG(c, d, a, b, x[k + 11], S23, 0x265E5A51);
  600. b = GG(b, c, d, a, x[k + 0], S24, 0xE9B6C7AA);
  601. a = GG(a, b, c, d, x[k + 5], S21, 0xD62F105D);
  602. d = GG(d, a, b, c, x[k + 10], S22, 0x2441453);
  603. c = GG(c, d, a, b, x[k + 15], S23, 0xD8A1E681);
  604. b = GG(b, c, d, a, x[k + 4], S24, 0xE7D3FBC8);
  605. a = GG(a, b, c, d, x[k + 9], S21, 0x21E1CDE6);
  606. d = GG(d, a, b, c, x[k + 14], S22, 0xC33707D6);
  607. c = GG(c, d, a, b, x[k + 3], S23, 0xF4D50D87);
  608. b = GG(b, c, d, a, x[k + 8], S24, 0x455A14ED);
  609. a = GG(a, b, c, d, x[k + 13], S21, 0xA9E3E905);
  610. d = GG(d, a, b, c, x[k + 2], S22, 0xFCEFA3F8);
  611. c = GG(c, d, a, b, x[k + 7], S23, 0x676F02D9);
  612. b = GG(b, c, d, a, x[k + 12], S24, 0x8D2A4C8A);
  613. a = HH(a, b, c, d, x[k + 5], S31, 0xFFFA3942);
  614. d = HH(d, a, b, c, x[k + 8], S32, 0x8771F681);
  615. c = HH(c, d, a, b, x[k + 11], S33, 0x6D9D6122);
  616. b = HH(b, c, d, a, x[k + 14], S34, 0xFDE5380C);
  617. a = HH(a, b, c, d, x[k + 1], S31, 0xA4BEEA44);
  618. d = HH(d, a, b, c, x[k + 4], S32, 0x4BDECFA9);
  619. c = HH(c, d, a, b, x[k + 7], S33, 0xF6BB4B60);
  620. b = HH(b, c, d, a, x[k + 10], S34, 0xBEBFBC70);
  621. a = HH(a, b, c, d, x[k + 13], S31, 0x289B7EC6);
  622. d = HH(d, a, b, c, x[k + 0], S32, 0xEAA127FA);
  623. c = HH(c, d, a, b, x[k + 3], S33, 0xD4EF3085);
  624. b = HH(b, c, d, a, x[k + 6], S34, 0x4881D05);
  625. a = HH(a, b, c, d, x[k + 9], S31, 0xD9D4D039);
  626. d = HH(d, a, b, c, x[k + 12], S32, 0xE6DB99E5);
  627. c = HH(c, d, a, b, x[k + 15], S33, 0x1FA27CF8);
  628. b = HH(b, c, d, a, x[k + 2], S34, 0xC4AC5665);
  629. a = II(a, b, c, d, x[k + 0], S41, 0xF4292244);
  630. d = II(d, a, b, c, x[k + 7], S42, 0x432AFF97);
  631. c = II(c, d, a, b, x[k + 14], S43, 0xAB9423A7);
  632. b = II(b, c, d, a, x[k + 5], S44, 0xFC93A039);
  633. a = II(a, b, c, d, x[k + 12], S41, 0x655B59C3);
  634. d = II(d, a, b, c, x[k + 3], S42, 0x8F0CCC92);
  635. c = II(c, d, a, b, x[k + 10], S43, 0xFFEFF47D);
  636. b = II(b, c, d, a, x[k + 1], S44, 0x85845DD1);
  637. a = II(a, b, c, d, x[k + 8], S41, 0x6FA87E4F);
  638. d = II(d, a, b, c, x[k + 15], S42, 0xFE2CE6E0);
  639. c = II(c, d, a, b, x[k + 6], S43, 0xA3014314);
  640. b = II(b, c, d, a, x[k + 13], S44, 0x4E0811A1);
  641. a = II(a, b, c, d, x[k + 4], S41, 0xF7537E82);
  642. d = II(d, a, b, c, x[k + 11], S42, 0xBD3AF235);
  643. c = II(c, d, a, b, x[k + 2], S43, 0x2AD7D2BB);
  644. b = II(b, c, d, a, x[k + 9], S44, 0xEB86D391);
  645. a = addUnsigned(a, AA);
  646. b = addUnsigned(b, BB);
  647. c = addUnsigned(c, CC);
  648. d = addUnsigned(d, DD);
  649. }
  650. let tempValue = wordToHex(a) + wordToHex(b) + wordToHex(c) + wordToHex(d);
  651. return tempValue.toLowerCase();
  652. };
  653. let base64EncodeChars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
  654. let base64DecodeChars = new Array(-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -1, -1, -1, -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1, -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, -1, -1, -1, -1, -1);
  655. /**
  656. * base64编码
  657. * @param {Object} str
  658. */
  659. function base64encode (str) {
  660. let out, i, len;
  661. let c1, c2, c3;
  662. len = str.length;
  663. i = 0;
  664. out = '';
  665. while (i < len) {
  666. c1 = str.charCodeAt(i++) & 0xff;
  667. if (i === len) {
  668. out += base64EncodeChars.charAt(c1 >> 2);
  669. out += base64EncodeChars.charAt((c1 & 0x3) << 4);
  670. out += '==';
  671. break;
  672. }
  673. c2 = str.charCodeAt(i++);
  674. if (i === len) {
  675. out += base64EncodeChars.charAt(c1 >> 2);
  676. out += base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
  677. out += base64EncodeChars.charAt((c2 & 0xF) << 2);
  678. out += '=';
  679. break;
  680. }
  681. c3 = str.charCodeAt(i++);
  682. out += base64EncodeChars.charAt(c1 >> 2);
  683. out += base64EncodeChars.charAt(((c1 & 0x3) << 4) | ((c2 & 0xF0) >> 4));
  684. out += base64EncodeChars.charAt(((c2 & 0xF) << 2) | ((c3 & 0xC0) >> 6));
  685. out += base64EncodeChars.charAt(c3 & 0x3F);
  686. }
  687. return out;
  688. }
  689. /**
  690. * base64解码
  691. * @param {Object} str
  692. */
  693. function base64decode (str) {
  694. let c1, c2, c3, c4;
  695. let i, len, out;
  696. len = str.length;
  697. i = 0;
  698. out = '';
  699. while (i < len) {
  700. /* c1 */
  701. do {
  702. c1 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
  703. }
  704. while (i < len && c1 === -1);
  705. if (c1 === -1) { break; }
  706. /* c2 */
  707. do {
  708. c2 = base64DecodeChars[str.charCodeAt(i++) & 0xff];
  709. }
  710. while (i < len && c2 === -1);
  711. if (c2 === -1) { break; }
  712. out += String.fromCharCode((c1 << 2) | ((c2 & 0x30) >> 4));
  713. /* c3 */
  714. do {
  715. c3 = str.charCodeAt(i++) & 0xff;
  716. if (c3 === 61) { return out; }
  717. c3 = base64DecodeChars[c3];
  718. }
  719. while (i < len && c3 === -1);
  720. if (c3 === -1) { break; }
  721. out += String.fromCharCode(((c2 & 0XF) << 4) | ((c3 & 0x3C) >> 2));
  722. /* c4 */
  723. do {
  724. c4 = str.charCodeAt(i++) & 0xff;
  725. if (c4 === 61) { return out; }
  726. c4 = base64DecodeChars[c4];
  727. }
  728. while (i < len && c4 === -1);
  729. if (c4 === -1) { break; }
  730. out += String.fromCharCode(((c3 & 0x03) << 6) | c4);
  731. }
  732. return out;
  733. }
  734. export default CryptoJS;