Passwords must be hashed before being stored using secure hash algorithms such as PBKDF2 and bcrypt.
A hash function maps data of arbitrary size to fixed-size values. It conceals sensitive information as it is often not possible to reverse hashed texts. Hashing passwords helps prevent unauthorized actors that may have accessed the storage system from obtaining them.
CWE-916: Use of Password Hash With Insufficient Computational Effort. The software generates a hash for a password, but it uses a scheme that does not provide a sufficient level of computational effort that would make password cracking attacks infeasible or expensive.
NIST 800-63B 220.127.116.11 Memorized Secret Verifiers Memorized secrets SHALL be salted and hashed using a suitable one-way key derivation function.
OWASP-ASVS v4.0.1 V2.4 Credential Storage Requirements.(2.4.1) Verify that passwords are stored in a form that is resistant to offline attacks. Passwords SHALL be salted and hashed using an approved one-way key derivation or password hashing function.
OWASP-ASVS v4.0.1 V2.4 Credential Storage Requirements.(2.4.3) Verify that if PBKDF2 is used, the iteration count SHOULD be as large as verification server performance will allow, typically at least 100,000 iterations.
OWASP-ASVS v4.0.1 V2.4 Credential Storage Requirements.(2.4.4) Verify that if bcrypt is used, the work factor SHOULD be as large as verification server performance will allow, typically at least 13.
PCI DSS v3.2.1 - Requirement 8.2.1 Using strong cryptography, render all authentication credentials (such as passwords/phrases) unreadable during transmission and storage on all system components.