logo
Home/CWEs/CWE-836/

CWE-836 - Use of Password Hash Instead of Password for Authentication

  • Abstraction:Base
  • Structure:Simple
  • Status:Incomplete
  • Release Date:2011-03-30
  • Latest Modification Date:2023-06-29

Weakness Name

Use of Password Hash Instead of Password for Authentication

Description

The product records password hashes in a data store, receives a hash of a password from a client, and compares the supplied hash to the hash obtained from the data store.

Some authentication mechanisms rely on the client to generate the hash for a password, possibly to reduce load on the server or avoid sending the password across the network. However, when the client is used to generate the hash, an attacker can bypass the authentication by obtaining a copy of the hash, e.g. by using SQL injection to compromise a database of authentication credentials, or by exploiting an information exposure. The attacker could then use a modified client to replay the stolen hash without having knowledge of the original password. As a result, the server-side comparison against a client-side hash does not provide any more security than the use of passwords without hashing.

Common Consequences

Scope: Access Control

Impact: Bypass Protection Mechanism, Gain Privileges or Assume Identity

Notes: An attacker could bypass the authentication routine without knowing the original password.

Related Weaknesses

CWE-602Client-Side Enforcement of Server-Side SecurityMedium

CWE-1390Weak Authentication