multihashing-async

2019-08-15

multihashing-async是什么

什么是multihashing-async,multiple hash functions

multihashing-async使用教程帮助文档

js-multihashing-async

Coverage StatusTravis CIDependency Statusjs-standard-style

Use all the functions in multihash.

Lead Maintainer

Hugo Dias

Notice

This module is moving to async/await starting from 0.7.0. The last minor version to support callbacks is 0.6.0, any backports will merged to the branch callbacksand released under >0.6.0 <0.7.0.

Wait, why, how is this different from Node crypto?

This module just makes working with multihashes a bit nicer. js-multihashis only for encoding/decoding multihashes, and does not depend on other libs. This module will depend on various implementations for each hash. It currently uses cryptoand sha3in Node.js. In the browser webcryptoand browserify-sha3are used.

Table of Contents

  • Table of Contents
  • Install
    • In Node.js through npm
    • Use in a browser with browserify, webpack or any other bundler
    • Use in a browser Using a script tag
      • Gotchas
  • Usage
  • Examples
    • Multihash output
  • API
  • Maintainers
  • Contribute
  • License

Install

In Node.js through npm

$ npm install --save multihashing-async
const multihashing = require('multihashing-async')

Use in a browser with browserify, webpack or any other bundler

The code published to npm that gets loaded on require is in fact a ES5 transpiled version with the right shims added. This means that you can require it and use with your favourite bundler without having to adjust asset management process.

const multihashing = require('multihashing-async')

Use in a browser Using a script tag

Loading this module through a script tag will make the multihashingobj available in the global namespace.

<script src="https://unpkg.com/multihashing-async/dist/index.min.js"></script>
<!-- OR -->
<script src="https://unpkg.com/multihashing-async/dist/index.js"></script>

Gotchas

You will need to use Node.js BufferAPI compatible, if you are running inside the browser, you can access it by multihashing.Bufferor you can install Feross's Buffer.

Usage

const multihashing = require('multihashing-async')
const buf = Buffer.from('beep boop')

const mh = await multihashing(buf, 'sha1')

// Use `.digest(...)` if you want only the hash digest (drops the prefix indicating the hash type).
const digest = await multihashing.digest(buf, 'sha1')

// Use `.createHash(...)` for the raw hash functions
const hash = multihashing.createHash('sha1')
const digest = await hash(buf)

Examples

Multihash output

const multihashing = require('multihashing-async')
const buf = Buffer.from('beep boop')

const mh = await multihashing(buf, 'sha1')
console.log(mh)
// => <Buffer 11 14 7c 83 57 57 7f 51 d4 f0 a8 d3 93 aa 1a aa fb 28 86 3d 94 21>

const mh = await multihashing(buf, 'sha2-256')
console.log(mh)
// => <Buffer 12 20 90 ea 68 8e 27 5d 58 05 67 32 50 32 49 2b 59 7b c7 72 21 c6 24 93 e7 63 30 b8 5d dd a1 91 ef 7c>

const mh = await multihashing(buf, 'sha2-512')
console.log(mh)
// => <Buffer 13 40 14 f3 01 f3 1b e2 43 f3 4c 56 68 93 78 83 77 1f a3 81 00 2f 1a aa 5f 31 b3 f7 8e 50 0b 66 ff 2f 4f 8e a5 e3 c9 f5 a6 1b d0 73 e2 45 2c 48 04 84 b0 ...>

API

https://multiformats.github.io/js-multihashing-async/

Contribute

Contributions welcome. Please check out the issues.

Check out our contributing documentfor more information on how we work, and about contributing in general. Please be aware that all interactions related to multiformats are subject to the IPFS Code of Conduct.

Small note: If editing the README, please conform to the standard-readmespecification.

License

MIT© Protocol Labs Inc.


上一篇:murmurhash3js-revisited
下一篇:interface-ipfs-core
相关教程
关注微信

扫码加入 JavaScript 社区

相关文章

首次访问,需要验证
微信扫码,关注即可
(仅需验证一次)

欢迎加入 JavaScript 社区

号内回复关键字:

回到顶部