base64.js 7.5 KB

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