Nodes inbyggda crypto-modul tillhandahåller kryptografiska funktioner: hashing, kryptering, slumpmässiga värden och HMAC. Den viktigaste praktiska användningen — lösenordshashing — har en kritisk regel: använd aldrig snabba, allmänna hash-algoritmer (MD5/SHA-256) för lösenord.
Lösenordshashing: använd en LÅNGSAM, saltad algoritm
{ scrypt, randomBytes, timingSafeEqual } ;
{ promisify } ;
scryptAsync = (scrypt);
() {
salt = ().();
derived = (password, salt, );
;
}
() {
[salt, hash] = stored.();
derived = (password, salt, );
hashBuf = .(hash, );
(hashBuf, derived);
}
