Skip to content

Instantly share code, notes, and snippets.

@ShapeGroup
Last active June 19, 2021 20:32
Show Gist options
  • Save ShapeGroup/67c6748ae47067b6619ac7580302b8a9 to your computer and use it in GitHub Desktop.
Save ShapeGroup/67c6748ae47067b6619ac7580302b8a9 to your computer and use it in GitHub Desktop.
js-kit-base-64-extended
//// JS KIT - BASE 64 EXTENDED MANAGER
//// MIT LICENCE
//// Credit: alberto marà
// how to use:
// var mydata = b64.encode('myjsobjectorstring');
// var mydata = b64.decode('myjsobjectorstring');
class B64CONVERTER
{
constructor()
{
this.key64();
this.encode();
this.decode();
this.utf8e();
this.utf8d();
}
key64() { B64.key = () =>{ return "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/="; }}
utf8e() { B64.utf8encode = (string) => {
string = string.replace(/\r\n/g,"\n");
var utftext = "";
for (var n = 0; n < string.length; n++) {
var c = string.charCodeAt(n);
if (c < 128) {
utftext += String.fromCharCode(c);
}
else if((c > 127) && (c < 2048)) {
utftext += String.fromCharCode((c >> 6) | 192);
utftext += String.fromCharCode((c & 63) | 128);
}
else {
utftext += String.fromCharCode((c >> 12) | 224);
utftext += String.fromCharCode(((c >> 6) & 63) | 128);
utftext += String.fromCharCode((c & 63) | 128);
}
}
return utftext;
}}
utf8d(utftext) { B64.utf8decode = (utftext) => {
var string = "", i = 0, c = c1, c1 = c2, c2 = 0;
while ( i < utftext.length )
{
c = utftext.charCodeAt(i);
if (c < 128) {
string += String.fromCharCode(c);
i++;
}
else if((c > 191) && (c < 224)) {
c2 = utftext.charCodeAt(i+1);
string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
i += 2;
}
else {
c2 = utftext.charCodeAt(i+1);
c3 = utftext.charCodeAt(i+2);
string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
i += 3;
}
}
return string;
}}
encode () { B64.encode = (input) => {
var output = "", chr1, chr2, chr3, enc1, enc2, enc3, enc4, i = 0;
input = B64.utf8encode(input);
while (i < input.length)
{
chr1 = input.charCodeAt(i++);
chr2 = input.charCodeAt(i++);
chr3 = input.charCodeAt(i++);
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
} else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
B64.key().charAt(enc1) + B64.key().charAt(enc2) +
B64.key().charAt(enc3) + B64.key().charAt(enc4);
}
return output;
}}
decode () { B64.decode = (input) => {
var output = "", chr1, chr2, chr3, enc1, enc2, enc3, enc4, i = 0;
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
while (i < input.length)
{
enc1 = B64.key().indexOf(input.charAt(i++));
enc2 = B64.key().indexOf(input.charAt(i++));
enc3 = B64.key().indexOf(input.charAt(i++));
enc4 = B64.key().indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
output = output + String.fromCharCode(chr1);
if (enc3 != 64) {
output = output + String.fromCharCode(chr2);
}
if (enc4 != 64) {
output = output + String.fromCharCode(chr3);
}
}
output = B64.utf8decode(output);
return output;
}}
}
const b64 = new B64CONVERTER();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment