
Research
Node.js Fixes AsyncLocalStorage Crash Bug That Could Take Down Production Servers
Node.js patched a crash bug where AsyncLocalStorage could cause stack overflows to bypass error handlers and terminate production servers.
@sindresorhus/base62
Advanced tools
Encode & decode strings, bytes, and integers to Base62
Base62 is ideal for URL shortening, creating readable codes, and compact data representation, because it compresses large values into shorter, alphanumeric strings, maximizing space efficiency and readability.
npm install @sindresorhus/base62
import base62 from '@sindresorhus/base62';
const encodedString = base62.encodeString('Hello world!');
console.log(encodedString);
//=> '28B5ymDkgSU62aA0v'
console.log(base62.decodeString(encodedString));
//=> 'Hello world!'
console.log(base62.encodeString('🦄'));
//=> '95s3vg'
console.log(base62.encodeInteger(1337));
//=> 'LZ'
[!NOTE] The output may differ from other Base62 encoders due to variations in alphabet order and byte encoding.
It uses the most common alphabet for Base62: 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
encodeString(string: string): stringEncodes a string to a Base62 string.
[!CAUTION] The result format is not yet guaranteed to be stable across package versions. Avoid using it for persistent storage.
decodeString(encodedString: string): stringDecodes a Base62 encoded string created with encodeString() back to the original string.
encodeBytes(bytes: Uint8Array): stringEncodes bytes to a Base62 string.
[!CAUTION] The result format is not yet guaranteed to be stable across package versions. Avoid using it for persistent storage.
decodeBytes(encodedString: string): Uint8ArrayDecodes a Base62 string created with encodeBytes() back to bytes.
encodeInteger(integer: number): stringEncodes a non-negative integer to a Base62 string.
decodeInteger(encodedString: string): numberDecodes a Base62 string to an integer.
encodeBigInt(integer: bigint): stringEncodes a non-negative bigint to a Base62 string.
decodeBigInt(encodedString: string): bigintDecodes a Base62 string to a bigint.
You can use a custom alphabet by using the Base62 class:
import {Base62} from '@sindresorhus/base62';
// Create instance with custom alphabet
const customBase62 = new Base62({
alphabet: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'
});
console.log(customBase62.encodeInteger(1337));
//=> 'Vj' (different from default 'LZ')
// Or use special characters
const symbolBase62 = new Base62({
alphabet: '!@#$%^&*()_+-=[]{}|;:,.<>?/~`0123456789ABCDEFGHIJKLMNOPQRSTUVW'
});
console.log(symbolBase62.encodeInteger(42));
//=> 'D'
[!NOTE] The alphabet must be exactly 62 unique characters.
Base62constructor(options?)Create a new Base62 encoder/decoder instance.
Type: object
Type: string
Default: '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
Custom alphabet containing exactly 62 unique characters.
The Base62 class has the same methods as the exported functions: encodeString(), decodeString(), encodeBytes(), decodeBytes(), encodeInteger(), decodeInteger(), encodeBigInt(), and decodeBigInt().
FAQs
Encode & decode strings, bytes, and integers to Base62
The npm package @sindresorhus/base62 receives a total of 487,660 weekly downloads. As such, @sindresorhus/base62 popularity was classified as popular.
We found that @sindresorhus/base62 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Research
Node.js patched a crash bug where AsyncLocalStorage could cause stack overflows to bypass error handlers and terminate production servers.

Research
/Security News
A malicious Chrome extension steals newly created MEXC API keys, exfiltrates them to Telegram, and enables full account takeover with trading and withdrawal rights.

Security News
CVE disclosures hit a record 48,185 in 2025, driven largely by vulnerabilities in third-party WordPress plugins.