JS btoa() and static Uint8Array.toBase64() yielding different results. Why?

Posted by OkEffect71@reddit | learnprogramming | View on Reddit | 6 comments

I use gzip compression on my audio file blob from the client. If if use btoa on the compressed string and decode it, it returns the original compressed blob [31,139 etc.]. And the encoded string looks like this: MzEsMTM5LDgsMCwwLDAsMCwwLDAsMywxNzEsMTc0LDUsMCw2NywxOTEsMTY2LDE2MywyLDAsMCww. And i also can't decode it on my server using node:zlib, it returns "incorrect header check" error (whether i'm using unzip or gunzip doesn't make a difference).

But if i use toBase64() it looks like this: H4sIAAAAAAAAA6uuBQBDv6ajAgAAAA==, and when decoded, it returns some weird symbols (like unicode replace symbols). And i'm not sure where i read this, but aren't compressed base64 strings supposed to have padding? Do these methods need to be decoded differently? this string also can be decoded on my server, but it returns an empty object.

I've also tried to replicate this code from stackoverflow:

const obj = {};
const zip = zlib.gzipSync(JSON.stringify(obj)).toString('base64');const obj = {};
const zip = zlib.gzipSync(JSON.stringify(obj)).toString('base64');

and for decompressing:

const originalObj = JSON.parse(zlib.unzipSync(Buffer.from(zip, 'base64')));
const originalObj = JSON.parse(zlib.unzipSync(Buffer.from(zip, 'base64')));

But toString("base64") doesn't work on objects/arrays in my tests.

I'm really lost and i've been reading forums and documentations for hours now. Why does this happen?