Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cryptocoinjs/bs58
Base58 encoding/decoding for Bitcoin
https://github.com/cryptocoinjs/bs58
Last synced: about 19 hours ago
JSON representation
Base58 encoding/decoding for Bitcoin
- Host: GitHub
- URL: https://github.com/cryptocoinjs/bs58
- Owner: cryptocoinjs
- License: mit
- Created: 2013-11-05T03:21:35.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2024-12-25T07:24:28.000Z (about 1 month ago)
- Last Synced: 2025-01-19T05:06:09.925Z (8 days ago)
- Language: JavaScript
- Homepage: http://cryptocoinjs.com/modules/misc/bs58/
- Size: 122 KB
- Stars: 218
- Watchers: 8
- Forks: 47
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
bs58
====[![build status](https://travis-ci.org/cryptocoinjs/bs58.svg)](https://travis-ci.org/cryptocoinjs/bs58)
JavaScript component to compute base 58 encoding. This encoding is typically used for crypto currencies such as Bitcoin.
**Note:** If you're looking for **base 58 check** encoding, see: [https://github.com/bitcoinjs/bs58check](https://github.com/bitcoinjs/bs58check), which depends upon this library.
Install
-------npm i --save bs58
API
---### encode(input)
`input` must be a `Uint8Array`, `Buffer`, or an `Array`. It returns a `string`.
**example**:
```js
import bs58 from 'bs58'const bytes = Uint8Array.from([
0, 60, 23, 110, 101, 155, 234,
15, 41, 163, 233, 191, 120, 128,
193, 18, 177, 179, 27, 77, 200,
38, 38, 129, 135
])
const address = bs58.encode(bytes)
console.log(address)
// => 16UjcYNBG9GTK4uq2f7yYEbuifqCzoLMGS
```### decode(input)
`input` must be a base 58 encoded string. Returns a Uint8Array.
**example**:
```js
import bs58 from 'bs58'const address = '16UjcYNBG9GTK4uq2f7yYEbuifqCzoLMGS'
const bytes = bs58.decode(address)
// See uint8array-tools package for helpful hex encoding/decoding/compare tools
console.log(Buffer.from(bytes).toString('hex'))
// => 003c176e659bea0f29a3e9bf7880c112b1b31b4dc826268187
```Browser
-----------
You can use this module in the browser. Install Browserify:```bash
npm install -g browserify
```then run:
```bash
browserify node_modules/bs58/cjs/index.cjs -o bs58.bundle.js --standalone bs58
```Hack / Test
-----------Uses JavaScript standard style. Read more:
[![js-standard-style](https://cdn.rawgit.com/feross/standard/master/badge.svg)](https://github.com/feross/standard)
Credits
-------
- [Mike Hearn](https://github.com/mikehearn) for original Java implementation
- [Stefan Thomas](https://github.com/justmoon) for porting to JavaScript
- [Stephan Pair](https://github.com/gasteve) for buffer improvements
- [Daniel Cousens](https://github.com/dcousens) for cleanup and merging improvements from bitcoinjs-lib
- [Jared Deckard](https://github.com/deckar01) for killing `bigi` as a dependencyLicense
-------MIT