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-06-16 18:44:29
最后一次提交2025-06-16 20:44:27
發布數63
最新版本名稱v0.43.0 (發布於 )
第一版名稱v0.1.1 (發布於 )
用户参与
星數2k
關注者數16
派生數97
提交數764
已啟用問題?
問題數245
打開的問題數4
拉請求數152
打開的拉請求數1
關閉的拉請求數60
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?