node-argon2

Node.js bindings for Argon2 hashing algorithm

Github星跟踪图

node-argon2

Open Collective backers
NPM package
Coverage status
Code Quality
Dependencies

  • Linux/OS X: Linux build status
  • Windows: Windows build status

Bindings to the reference Argon2
implementation.

Want to use it on command line? Instead check
node-argon2-cli.

Usage

It's possible to hash using either Argon2i (default), Argon2d and Argon2id, and
verify if a password matches a hash.

To hash a password:

const argon2 = require('argon2');

try {
  const hash = await argon2.hash("password");
} catch (err) {
  //...
}

To see how you can modify the output (hash length, encoding) and parameters
(time cost, memory cost and parallelism),
read the wiki

To verify a password:

try {
  if (await argon2.verify("<big long hash>", "password")) {
    // password match
  } else {
    // password did not match
  }
} catch (err) {
  // internal failure
}

TypeScript Usage

A TypeScript type declaration file is published with this module. If you are
using TypeScript >= 2.0.0 that means you do not need to install any additional
typings in order to get access to the strongly typed interface. Simply use the
library as mentioned above. This library uses Promises, so make sure you are
targeting ES6+, including the es2015.promise lib in your build, or globally
importing a Promise typings library.

Some example tsconfig.json compiler options:

{
    "compilerOptions": {
        "lib": ["es2015.promise"]
    }
}

or

{
    "compilerOptions": {
        "target": "es6"
    }
}
import * as argon2 from "argon2";

const hash = await argon2.hash(..);

Differences from node-argon2-ffi

This library is implemented natively, meaning it is an extension to the node
engine. Thus, half of the code are C++ bindings, the other half are Javascript
functions. node-argon2-ffi uses ffi, a mechanism to call functions from one
language in another, and handles the type bindings (e.g. JS Number -> C++ int).

The interface of both are very similar, notably node-argon2-ffi splits the
argon2i and argon2d function set, but this module also has the argon2id option.
Also, while node-argon2-ffi suggests you promisify crypto.randomBytes, this
library does that internally.

Performance-wise, the libraries are equal. You can run the same benchmark suite
if you are curious, but both can perform around 130 hashes/second on an Intel
Core i5-4460 @ 3.2GHz with default options.

Before installing

You MUST have a node-gyp global install before proceeding with install,
along with GCC >= 5 / Clang >= 3.3. On Windows, you must compile under Visual
Studio 2015 or newer.

node-argon2 works only and is tested against Node >=8.0.0.

OSX

To install GCC >= 5 on OSX, use homebrew:

$ brew install gcc

Once you've got GCC installed and ready to run, you then need to install
node-gyp, you must do this globally:

$ npm install -g node-gyp

Finally, once node-gyp is installed and ready to go, you can install this
library, specifying the GCC or Clang binary to use:

$ CXX=g++-6 npm install argon2

NOTE: If your GCC or Clang binary is named something different than g++-6,
you'll need to specify that in the command.

License

Work licensed under the MIT License. Please check
P-H-C/phc-winner-argon2 for
license over Argon2 and the reference implementation.

主要指标

概览
名称与所有者ranisalt/node-argon2
主编程语言JavaScript
编程语言C++ (语言数: 2)
平台
许可证MIT License
所有者活动
创建于2015-12-19 09:50:48
推送于2025-04-24 11:37:31
最后一次提交2025-04-24 13:37:30
发布数63
最新版本名称v0.43.0 (发布于 )
第一版名称v0.1.1 (发布于 )
用户参与
星数2k
关注者数16
派生数97
提交数759
已启用问题?
问题数243
打开的问题数2
拉请求数149
打开的拉请求数1
关闭的拉请求数60
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?