Vestavěný modul Node crypto poskytuje kryptografické funkce: hashing, šifrování, náhodné hodnoty a HMAC. Nejdůležitější praktické použití — hashování hesel — má kritické pravidlo: nikdy nepoužívejte rychlé, obecné hashe (MD5/SHA-256) pro hesla.
Hashování hesel: použijte pomalý, solený algoritmus
{ scrypt, randomBytes, timingSafeEqual } ;
{ promisify } ;
scryptAsync = (scrypt);
() {
salt = ().();
derived = (password, salt, );
;
}
() {
[salt, hash] = stored.();
derived = (password, salt, );
hashBuf = .(hash, );
(hashBuf, derived);
}
