Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
The base62 npm package provides utilities for encoding and decoding data using the Base62 encoding scheme. Base62 encoding is commonly used for shortening URLs, creating compact representations of data, and other applications where a compact, alphanumeric representation is beneficial.
Encoding
This feature allows you to encode a number into a Base62 string. The example encodes the number 12345 into the Base62 string 'dnh'.
const base62 = require('base62/lib/ascii');
const encoded = base62.encode(12345);
console.log(encoded); // Output: 'dnh'
Decoding
This feature allows you to decode a Base62 string back into a number. The example decodes the Base62 string 'dnh' back into the number 12345.
const base62 = require('base62/lib/ascii');
const decoded = base62.decode('dnh');
console.log(decoded); // Output: 12345
The base-x package is a versatile encoding library that supports custom base encoding schemes, including Base62. It is more flexible than base62 as it allows you to define your own character set for encoding and decoding.
The base64url package provides Base64 URL-safe encoding and decoding. While it focuses on Base64 rather than Base62, it is useful for similar applications where URL-safe encoding is required.
The btoa package provides Base64 encoding and decoding for Node.js. It is a simple and lightweight alternative for Base64 encoding, but does not support Base62.
A JavaScript Base62 encode/decoder
Base62 encoding converts numbers to ASCII strings (0-9, a-z and A-Z) and vice versa, which typically results in comparatively short strings. Such identifiers also tend to more readily identifiable by humans.
999
≙ "g7"
9999
≙ "2Bh"
238327
≙ "ZZZ"
npm install base62
alternatively using Yarn:
yarn add base62
For backwards compatibility, Base62.js exposes v1.x's API by default – see Legacy API below. For efficiency, v2.x's modernized API allows selectively importing individual modules instead:
var base62 = require("base62/lib/ascii");
base62.encode(999); // "g7"
base62.decode("g7"); // 999
This uses the default ASCII character set for encoding/decoding.
It's also possible to define a custom character set instead:
var base62 = require("base62/lib/custom");
var charset = "~9876543210ABCDEFGHIJKLMNOPQRSTU$#@%!abcdefghijklmnopqrstuvw-=";
charset = base62.indexCharset(charset);
base62.encode(999, charset); // "F3"
base62.decode("F3", charset); // 999
Note that indexCharset
typically expects the respective string to contain
exactly 62 unique character, but does not validate this for efficieny. In fact,
it's also possible to use characters sets with more than 62 characters in order
to achieve shorter identifiers for large numbers.
Base62.js v1.x's API is maintained for backwards compatibility.
var base62 = require("base62");
base62.encode(999); // "g7"
base62.decode("g7"); // 999
This uses the default ASCII character set for encoding/decoding.
It's also possible to define a custom character set instead:
var base62 = require("base62");
var charset = "~9876543210ABCDEFGHIJKLMNOPQRSTU$#@%!abcdefghijklmnopqrstuvw-=";
base62.setCharacterSet(charset);
base62.encode(999); // "F3"
base62.decode("F3"); // 999
setCharacterSet
ensures that the respective string contains exactly 62 unique
characters.
Source code is hosted on GitHub. Please report issues or feature requests in GitHub Issues.
package.json
.git tag -am "1.2.3" v1.2.3
).git push --tags origin master
and npm publish
.Copyright (c) 2016 Andrew Nesbitt. See LICENSE for details.
FAQs
JavaScript Base62 encode/decoder
The npm package base62 receives a total of 88,507 weekly downloads. As such, base62 popularity was classified as popular.
We found that base62 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers 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
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.