在我的node.js应用程序中,我做了一个npm安装btoa-atob,这样我就可以使用btoa()和atob()函数,这些函数在客户端javascript中是原生的,但由于某种原因没有包含在node中。新目录出现在我的node_modules文件夹中,它本身和app.js一起在根目录下。然后我确保在包中添加btoa-atob作为依赖项。Json文件,在根目录下。

然而,由于某种原因,它仍然不能工作。

console.log(btoa("Hello World!"));

^应该输出“SGVsbG8gV29ybGQh”到控制台,但是相反,我得到了错误:

Btoa没有定义。

我没有正确地安装吗?我忽略了什么?


当前回答

想要解码的人:

let decoded = Buffer.from(<encoded string>, 'base64').toString()

因为我来这里寻找解码,最后从这里的答案中找到了答案。

其他回答

我能够使用btoa的二进制数据到基于64字符串转换使用下面的npm包: https://www.npmjs.com/package/btoa

正如他们的文档中所描述的,我在node JS应用程序中做了以下步骤:

Install => npm Install——保存btoa Declare at top => const btoa = require('btoa'); 使用=> const b64 = btoa("stringToEncode");

'btoa-atob'模块不导出编程接口,它只提供命令行实用程序。

如果你需要转换为Base64,你可以使用Buffer:

console.log(Buffer.from('Hello World!').toString('base64'));

反向(假设你解码的内容是utf8字符串):

console.log(Buffer.from(b64Encoded, 'base64').toString());

注意:在Node v4之前,使用new Buffer而不是Buffer.from。

我的团队在与React Native和PouchDB一起使用Node时遇到了这个问题。下面是我们的解决方法……

NPM安装缓冲区:

$ npm install --save buffer

确保Buffer、btoa和atob作为全局变量加载:

global.Buffer = global.Buffer || require('buffer').Buffer;

if (typeof btoa === 'undefined') {
  global.btoa = function (str) {
    return new Buffer(str, 'binary').toString('base64');
  };
}

if (typeof atob === 'undefined') {
  global.atob = function (b64Encoded) {
    return new Buffer(b64Encoded, 'base64').toString('binary');
  };
}

下面是一个简洁的base64编码通用解决方案:

const nodeBtoa = (b) => Buffer.from(b).toString('base64');
export const base64encode = typeof btoa !== 'undefined' ? btoa : nodeBtoa;

我发现,尽管上述答案中的shims工作,但它们与桌面浏览器的btoa()和atob()实现的行为不匹配:

const btoa = function(str){ return Buffer.from(str).toString('base64'); }
// returns "4pyT", yet in desktop Chrome would throw an error.
btoa('✓');
// returns "fsO1w6bCvA==", yet in desktop Chrome would return "fvXmvA=="
btoa(String.fromCharCode.apply(null, new Uint8Array([0x7e, 0xf5, 0xe6, 0xbc])));

事实证明,Buffer实例在默认情况下表示/解释UTF-8编码的字符串。相比之下,在桌面Chrome中,你甚至不能输入一个包含latin1范围之外的字符的字符串到btoa(),因为它会抛出一个异常:Uncaught DOMException: Failed to execute 'btoa' on 'Window':要编码的字符串包含latin1范围之外的字符。

因此,你需要显式地将编码类型设置为latin1,以便让你的Node.js shim匹配桌面Chrome的编码类型:

const btoaLatin1 = function(str) { return Buffer.from(str, 'latin1').toString('base64'); }
const atobLatin1 = function(b64Encoded) {return Buffer.from(b64Encoded, 'base64').toString('latin1');}

const btoaUTF8 = function(str) { return Buffer.from(str, 'utf8').toString('base64'); }
const atobUTF8 = function(b64Encoded) {return Buffer.from(b64Encoded, 'base64').toString('utf8');}

btoaLatin1('✓'); // returns "Ew==" (would be preferable for it to throw error because this is undecodable)
atobLatin1(btoa('✓')); // returns "\u0019" (END OF MEDIUM)

btoaUTF8('✓'); // returns "4pyT"
atobUTF8(btoa('✓')); // returns "✓"

// returns "fvXmvA==", just like desktop Chrome
btoaLatin1(String.fromCharCode.apply(null, new Uint8Array([0x7e, 0xf5, 0xe6, 0xbc])));
// returns "fsO1w6bCvA=="
btoaUTF8(String.fromCharCode.apply(null, new Uint8Array([0x7e, 0xf5, 0xe6, 0xbc])));