Reputation: 14789
In Javascript, window.atob()
method decodes a base64 string and window.btoa()
method encodes a string
into base64.
Then why weren't they named like base64Decode()
and base64Encode()
?
atob()
and btoa()
don't make sense because they're not semantic at all.
I want to know the reason.
Upvotes: 450
Views: 136237
Reputation: 6190
I can't locate a source at the moment, but it is common knowledge that in this case, the b stands for 'binary', and the a for 'ASCII'.
Therefore, the functions are actually named:
ASCII to Binary for atob()
, and
Binary to ASCII for btoa()
.
Alos, note that this is browser implementation and was left for legacy / backward compatibility purposes. In Node.js, you would use:
Buffer.from("Hello World").toString('base64')
Buffer.from("SGVsbG8gV29ybGQ=", 'base64').toString('ascii')
Upvotes: 10
Reputation: 3133
I asked Brendan Eich (the creator of JavaScript) if he picked those names on Twitter and he responded:
Old Unix names, hard to find man pages rn but see https://www.unix.com/man-page/minix/1/btoa/ …. The names carried over from Unix into the Netscape codebase. I reflected them into JS in a big hurry in 1995 (after the ten days in May but soon).
In case the Minix link breaks, here's the man page content:
BTOA(1) BTOA(1)
NAME
btoa - binary to ascii conversion
SYNOPSIS
btoa [-adhor] [infile] [outfile]
OPTIONS
-a Decode, rather than encode, the file
-d Extracts repair file from diagnosis file
-h Help menu is displayed giving the options
-o The obsolete algorithm is used for backward compatibility
-r Repair a damaged file
EXAMPLES
btoa <a.out >a.btoa # Convert a.out to ASCII
btoa -a <a.btoa >a.out
# Reverse the above
DESCRIPTION
Btoa is a filter that converts a binary file to ascii for transmission over a telephone
line. If two file names are provided, the first in used for input and the second for out-
put. If only one is provided, it is used as the input file. The program is a function-
ally similar alternative to uue/uud, but the encoding is completely different. Since both
of these are widely used, both have been provided with MINIX. The file is expanded about
25 percent in the process.
SEE ALSO
uue(1), uud(1).
Upvotes: 275
Reputation: 2677
The names come from a unix function with similar functionality, but you can already read that in other answers here.
Here is my mnemonic to remember which one to use. This doesn't really answer the question itself, but might help people figure which one of the functions to use without keeping a tab open on this question on stack overflow all day long.
btoa
Take something Beautiful (aka, beautiful content that would make sense to your application: json, xml, text, binary data) and transform it to something Awful, that cannot be understood as is (aka: encoded).
atob
The exact opposite of btoa
Some may say that binary is not beautiful, but hey, this is only a trick to help you.
Upvotes: 95
Reputation: 2703
To sum up the already given answers:
atob
stands for ASCII to binary
atob("ZXhhbXBsZSELCg==") == "example!^K"
btoa
stands for binary to ASCII
btoa("\x01\x02\xfe\xff") == "AQL+/w=="
Why ASCII and binary:
ASCII
(the a
) is the result of base64
encoding. A safe text composed only of a subset of ascii characters(*) that can be correctly represented and transported (e.g. email's body),binary
(the b
) is any stream of 0s and 1s (in javascript it must be represented with a string type).(*) in base64
these are limited to: A-Z
, a-z
, 0-9
, +
, /
and =
(padding, only at the end) https://en.wikipedia.org/wiki/Base64
P.S. I must admit I myself was initially confused by the naming and thought the names were swapped. I thought that b
stand for "base64 encoded string" and a
for "any string" :D.
Upvotes: 189
Reputation: 9993
The atob()
and btoa()
methods allow authors to transform content to and from the base64 encoding.
In these APIs, for mnemonic purposes, the "b" can be considered to stand for "binary", and the "a" for "ASCII". In practice, though, for primarily historical reasons, both the input and output of these functions are Unicode strings.
From : http://www.w3.org/TR/html/webappapis.html#atob
Upvotes: 217