base64.js 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. /* eslint-disable */
  2. // https://github.com/locutusjs/locutus/blob/master/src/php/xml/utf8_encode.js
  3. function utf8Encode(argString) {
  4. // http://kevin.vanzonneveld.net
  5. // + original by: Webtoolkit.info (http://www.webtoolkit.info/)
  6. // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  7. // + improved by: sowberry
  8. // + tweaked by: Jack
  9. // + bugfixed by: Onno Marsman
  10. // + improved by: Yves Sucaet
  11. // + bugfixed by: Onno Marsman
  12. // + bugfixed by: Ulrich
  13. // + bugfixed by: Rafal Kukawski
  14. // + improved by: kirilloid
  15. // + bugfixed by: kirilloid
  16. // * example 1: this.utf8Encode('Kevin van Zonneveld')
  17. // * returns 1: 'Kevin van Zonneveld'
  18. if (argString === null || typeof argString === 'undefined') {
  19. return '';
  20. }
  21. var string = argString + ''; // .replace(/\r\n/g, '\n').replace(/\r/g, '\n')
  22. var utftext = '', start, end, stringl = 0;
  23. start = end = 0;
  24. stringl = string.length;
  25. for (var n = 0; n < stringl; n++) {
  26. var c1 = string.charCodeAt(n);
  27. var enc = null;
  28. if (c1 < 128) {
  29. end++;
  30. }
  31. else if (c1 > 127 && c1 < 2048) {
  32. enc = String.fromCharCode((c1 >> 6) | 192, (c1 & 63) | 128);
  33. }
  34. else if ((c1 & 0xf800 ^ 0xd800) > 0) {
  35. enc = String.fromCharCode((c1 >> 12) | 224, ((c1 >> 6) & 63) | 128, (c1 & 63) | 128);
  36. }
  37. else {
  38. // surrogate pairs
  39. if ((c1 & 0xfc00 ^ 0xd800) > 0) {
  40. throw new RangeError('Unmatched trail surrogate at ' + n);
  41. }
  42. var c2 = string.charCodeAt(++n);
  43. if ((c2 & 0xfc00 ^ 0xdc00) > 0) {
  44. throw new RangeError('Unmatched lead surrogate at ' + (n - 1));
  45. }
  46. c1 = ((c1 & 0x3ff) << 10) + (c2 & 0x3ff) + 0x10000;
  47. enc = String.fromCharCode((c1 >> 18) | 240, ((c1 >> 12) & 63) | 128, ((c1 >> 6) & 63) | 128, (c1 & 63) | 128);
  48. }
  49. if (enc !== null) {
  50. if (end > start) {
  51. utftext += string.slice(start, end);
  52. }
  53. utftext += enc;
  54. start = end = n + 1;
  55. }
  56. }
  57. if (end > start) {
  58. utftext += string.slice(start, stringl);
  59. }
  60. return utftext;
  61. }
  62. // https://github.com/locutusjs/locutus/blob/master/src/php/xml/utf8_decode.js
  63. function utf8Decode(strData) {
  64. // eslint-disable-line camelcase
  65. // discuss at: https://locutus.io/php/utf8_decode/
  66. // original by: Webtoolkit.info (https://www.webtoolkit.info/)
  67. // input by: Aman Gupta
  68. // input by: Brett Zamir (https://brett-zamir.me)
  69. // improved by: Kevin van Zonneveld (https://kvz.io)
  70. // improved by: Norman "zEh" Fuchs
  71. // bugfixed by: hitwork
  72. // bugfixed by: Onno Marsman (https://twitter.com/onnomarsman)
  73. // bugfixed by: Kevin van Zonneveld (https://kvz.io)
  74. // bugfixed by: kirilloid
  75. // bugfixed by: w35l3y (https://www.wesley.eti.br)
  76. // example 1: utf8_decode('Kevin van Zonneveld')
  77. // returns 1: 'Kevin van Zonneveld'
  78. var tmpArr = [];
  79. var i = 0;
  80. var c1 = 0;
  81. var seqlen = 0;
  82. strData += '';
  83. while (i < strData.length) {
  84. c1 = strData.charCodeAt(i) & 0xFF;
  85. seqlen = 0;
  86. // https://en.wikipedia.org/wiki/UTF-8#Codepage_layout
  87. if (c1 <= 0xBF) {
  88. c1 = (c1 & 0x7F);
  89. seqlen = 1;
  90. }
  91. else if (c1 <= 0xDF) {
  92. c1 = (c1 & 0x1F);
  93. seqlen = 2;
  94. }
  95. else if (c1 <= 0xEF) {
  96. c1 = (c1 & 0x0F);
  97. seqlen = 3;
  98. }
  99. else {
  100. c1 = (c1 & 0x07);
  101. seqlen = 4;
  102. }
  103. for (var ai = 1; ai < seqlen; ++ai) {
  104. c1 = ((c1 << 0x06) | (strData.charCodeAt(ai + i) & 0x3F));
  105. }
  106. if (seqlen === 4) {
  107. c1 -= 0x10000;
  108. tmpArr.push(String.fromCharCode(0xD800 | ((c1 >> 10) & 0x3FF)));
  109. tmpArr.push(String.fromCharCode(0xDC00 | (c1 & 0x3FF)));
  110. }
  111. else {
  112. tmpArr.push(String.fromCharCode(c1));
  113. }
  114. i += seqlen;
  115. }
  116. return tmpArr.join('');
  117. }
  118. function base64Encode(data) {
  119. // http://kevin.vanzonneveld.net
  120. // + original by: Tyler Akins (http://rumkin.com)
  121. // + improved by: Bayron Guevara
  122. // + improved by: Thunder.m
  123. // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  124. // + bugfixed by: Pellentesque Malesuada
  125. // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  126. // - depends on: this.utf8Encode
  127. // * example 1: this.base64Encode('Kevin van Zonneveld')
  128. // * returns 1: 'S2V2aW4gdmFuIFpvbm5ldmVsZA=='
  129. // mozilla has this native
  130. // - but breaks in 2.0.0.12!
  131. // if (typeof this.window['atob'] == 'function') {
  132. // return atob(data)
  133. // }
  134. var b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';
  135. var o1, o2, o3, h1, h2, h3, h4, bits, i = 0, ac = 0, enc = '', tmp_arr = [];
  136. if (!data) {
  137. return data;
  138. }
  139. data = utf8Encode(data + '');
  140. do {
  141. // pack three octets into four hexets
  142. o1 = data.charCodeAt(i++);
  143. o2 = data.charCodeAt(i++);
  144. o3 = data.charCodeAt(i++);
  145. bits = (o1 << 16) | (o2 << 8) | o3;
  146. h1 = (bits >> 18) & 0x3f;
  147. h2 = (bits >> 12) & 0x3f;
  148. h3 = (bits >> 6) & 0x3f;
  149. h4 = bits & 0x3f;
  150. // use hexets to index into b64, and append result to encoded string
  151. tmp_arr[ac++] =
  152. b64.charAt(h1) + b64.charAt(h2) + b64.charAt(h3) + b64.charAt(h4);
  153. } while (i < data.length);
  154. enc = tmp_arr.join('');
  155. switch (data.length % 3) {
  156. case 1:
  157. enc = enc.slice(0, -2) + '==';
  158. break;
  159. case 2:
  160. enc = enc.slice(0, -1) + '=';
  161. break;
  162. }
  163. return enc;
  164. }
  165. function base64Decode(data) {
  166. // http://kevin.vanzonneveld.net
  167. // + original by: Tyler Akins (http://rumkin.com)
  168. // + improved by: Thunder.m
  169. // + input by: Aman Gupta
  170. // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  171. // + bugfixed by: Onno Marsman
  172. // + bugfixed by: Pellentesque Malesuada
  173. // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  174. // + input by: Brett Zamir (http://brett-zamir.me)
  175. // + bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  176. // * example 1: base64_decode('S2V2aW4gdmFuIFpvbm5ldmVsZA==')
  177. // * returns 1: 'Kevin van Zonneveld'
  178. // mozilla has this native
  179. // - but breaks in 2.0.0.12!
  180. // if (typeof this.window['atob'] == 'function') {
  181. // return atob(data)
  182. // }
  183. var b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';
  184. var o1, o2, o3, h1, h2, h3, h4, bits, i = 0, ac = 0, dec = '', tmp_arr = [];
  185. if (!data) {
  186. return data;
  187. }
  188. data += '';
  189. do { // unpack four hexets into three octets using index points in b64
  190. h1 = b64.indexOf(data.charAt(i++));
  191. h2 = b64.indexOf(data.charAt(i++));
  192. h3 = b64.indexOf(data.charAt(i++));
  193. h4 = b64.indexOf(data.charAt(i++));
  194. bits = h1 << 18 | h2 << 12 | h3 << 6 | h4;
  195. o1 = bits >> 16 & 0xff;
  196. o2 = bits >> 8 & 0xff;
  197. o3 = bits & 0xff;
  198. if (h3 === 64) {
  199. tmp_arr[ac++] = String.fromCharCode(o1);
  200. }
  201. else if (h4 === 64) {
  202. tmp_arr[ac++] = String.fromCharCode(o1, o2);
  203. }
  204. else {
  205. tmp_arr[ac++] = String.fromCharCode(o1, o2, o3);
  206. }
  207. } while (i < data.length);
  208. dec = tmp_arr.join('');
  209. return utf8Decode(dec);
  210. }
  211. export function urlSafeBase64Encode(v) {
  212. v = base64Encode(v);
  213. // 参考 https://tools.ietf.org/html/rfc4648#section-5
  214. return v.replace(/\//g, '_').replace(/\+/g, '-');
  215. }
  216. export function urlSafeBase64Decode(v) {
  217. v = v.replace(/_/g, '/').replace(/-/g, '+');
  218. return base64Decode(v);
  219. }
  220. //# sourceMappingURL=base64.js.map