@47ng/codec
Universal conversion of Uint8Array from/into UTF-8, base64url and hex in the browser and Node.js
Features
Available codecs:
utf8
- UTF-8b64
- Base 64 URL (RFC-4648, Section 5)hex
- Hexadecimal, lowercase- Simple conversion between string representation
- Encoding detection
Watch out !
utf8
uses a different convention than the other codecs (encode and decode
are swapped), to reflect how TextEncoder
and TextDecoder
behave.
Installation
$ yarn add @47ng/codec
# or
$ npm i @47ng/codec
Support
- Node.js: >=11.x
- Browser: See caniuse for
TextEncoder
/ TextDecoder
Examples
import { b64, hex, utf8 } from '@47ng/codec'
b64.encode(utf8.encode('Hello, World !'))
hex.encode(b64.decode('SGVsbG8sIFdvcmxkICE='))
utf8.decode(hex.decode('48656c6c6f2c20576f726c642021'))
b64.decode('SGVsbG8sIFdvcmxkICE=')
Documentation
UTF-8
utf8.encode
: Convert an UTF-8 string into an array of bytes (Uint8Array)utf8.decode
: Convert an array of bytes into an UTF-8 string
Examples:
import { utf8 } from '@47ng/codec'
const uint8Array = utf8.encode('Hello, World!')
const backToText = utf8.decode(uint8Array)
Base 64
b64.encode
: Convert an array of bytes into a base64url stringb64.decode
: Convert a base64 string into an array of bytesb64.urlSafe
: Convert a standard base64 string to base64urlb64.urlUnsafe
: Convert a base64url string to standard base64 dictionary
Note: For decoding, any dictionary is supported, and trailing padding (=
) is optional.
Examples:
import { b64, utf8 } from '@47ng/codec'
const uint8Array = b64.decode('8J-Ri_CfjI0')
const backToBase64 = b64.encode(uint8Array)
const asText = utf8.decode(uint8Array)
Hex
hex.encode
: Convert an array of bytes into a hex stringhex.decode
: Convert a hex string into an array of bytes
Note: Decoding accepts any case (lowercase, uppercase, mixed).
Examples:
import { hex } from '@47ng/codec'
const uint8Array = hex.decode('48656C6C6F2C20576f726c642021')
const backToBase64 = hex.encode(uint8Array)
Utilities
The library exports convenience methods for converting from one string
representation to another:
import {
hexToBase64url,
base64ToHex,
utf8ToBase64,
base64toUTF8,
utf8ToHex,
hexToUTF8
} from '@47ng/codec'
base64ToHex('SGVsbG8sIFdvcmxkICE=')
hexToBase64url('48656c6c6f2c20576f726c642021')
utf8ToBase64('Hello, World !')
base64toUTF8('SGVsbG8sIFdvcmxkICE=')
utf8ToHex('Hello, World !')
hexToUTF8('48656c6c6f2c20576f726c642021')
It also exports encoder / decoder objects with strong TypeScript types, to help you
build your own encoders & decoders:
import { encoders, decoders, Encoding } from '@47ng/codec'
function convert(
input: string,
inputEncoding: Encoding,
outputEncoding: Encoding
): string {
const decoder = decoders[inputEncoding]
const encoder = encoders[outputEncoding]
return encoder(decoder(input))
}
convert('Hello, World!', 'utf8', 'base64')
convert('Hello, World!', 'utf8', 'hex')
You can detect the encoding of a string:
import { detectEncoding } from '@47ng/codec'
detectEncoding('baadf00dcafebabe')
detectEncoding('SGVs+G8s/FdvcmxkICE=')
detectEncoding('SGVs-G8s_FdvcmxkICE=')
detectEncoding('not hex not base64')
License
MIT - Made with ❤️ by
François Best.
Using this package at work ? Sponsor me to help with support and maintenance.