Design and Analysis of Password-Based Key Derivation Functions

F.F. Yao,Y.L. Yin
DOI: https://doi.org/10.1109/tit.2005.853307
IF: 2.5
2005-09-01
IEEE Transactions on Information Theory
Abstract:A password-based key derivation function (KDF)—a function that derives cryptographic keys from a password—is necessary in many security applications. Like any password-based schemes, such KDFs are subject to key search attacks (often called dictionary attacks). Salt and iteration count are used in practice to significantly increase the workload of such attacks. These techniques have also been specified in widely adopted industry standards such as PKCS and IETF. Despite the importance and widespread usage, there has been no formal security analysis on existing constructions. In this correspondence, we propose a general security framework for password-based KDFs and introduce two security definitions each capturing a different attacking scenario. We study the most commonly used construction $H^{(c)}(p\,\Vert\, s)$ and prove that the iteration count $c$, when fixed, does have an effect of stretching the password $p$ by $\log_2 c$ bits. We then analyze the two standardized KDFs in PKCS #5. We show that both are secure if the adversary cannot influence the parameters but subject to attacks otherwise. Finally, we propose a new password-based KDF that is provably secure even when the adversary has full control of the parameters.
computer science, information systems,engineering, electrical & electronic
What problem does this paper attempt to address?