Misplaced Pages

Rainbow table: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editNext edit →Content deleted Content addedVisualWikitext
Revision as of 10:52, 4 January 2006 edit131.215.155.151 (talk) External links← Previous edit Revision as of 16:15, 6 January 2006 edit undoAlex.g (talk | contribs)Extended confirmed users584 edits added some links, removed "highly compressed" phrase which can be easily confused with data compressionNext edit →
Line 1: Line 1:
A '''rainbow table''' is a special type of ] that is constructed by placing a plaintext password entry in a chain of keys and cyphertexts, generated by a ]. The end result is a highly compressed table that contains statistically high chance of revealing a password within a short period of time, generally less than a minute. The success probability of the table depends on the parameters used to generate it. These include the character set used, password length, chain length, table count. Tables are hash specific, e.g. MD5 tables can only crack MD5 hashes. The theory of this technique was first pioneered by Philippe Oechslin as a fast form of ] (PDF), which he implemented in the Windows password cracker ]. The more powerful ] program was later developed that can generate and use rainbow tables for a variety of character sets and hashing algorithms, including ], ], ], etc. A '''rainbow table''' is a special type of ] that is constructed by placing a ] ] entry in a chain of ] and cyphertexts, generated by a ]. The end result is a table that contains statistically high chance of revealing a password within a short period of time, generally less than a minute. The success probability of the table depends on the parameters used to generate it. These include the character set used, password length, chain length, table count. Tables are hash specific, e.g. MD5 tables can only crack MD5 hashes. The theory of this technique was first pioneered by Philippe Oechslin as a fast form of ] (PDF), which he implemented in the ] ] ]. The more powerful ] program was later developed that can generate and use rainbow tables for a variety of character sets and hashing algorithms, including ], ], ], etc.


==Defense against rainbow tables== ==Defense against rainbow tables==
A rainbow table is essentially worthless against one-way hashes that include tokens (or salts, in the case of 56-bit ]). For example, if a password hash is generated using the following function (where "." is the ] operator): A rainbow table is essentially worthless against one-way hashes that include tokens (or ], in the case of 56-bit ]). For example, if a password hash is generated using the following function (where "." is the ] operator):
hash = md5sum(password . token) hash = md5sum(password . token)
...a password cracker would have to generate both every possible token for every possible password — a rainbow table would not give any benefit. However, if a password hash is generated using the following function: ...a password cracker would have to generate both every possible token for every possible password — a rainbow table would not give any benefit. However, if a password hash is generated using the following function:
Line 8: Line 8:
...a password cracker may benefit from a rainbow table. ...a password cracker may benefit from a rainbow table.


Nearly all distributions and variations of ], ], and ] use one-way hashes and salts, though many ] web applications use regular MD5. The Windows NT/2000 family of windows uses the LAN Manager and NT LAN Manager hashing method and is also unsalted, which make it one of the more popularly generated tables. Nearly all distributions and variations of ], ], and ] use one-way hashes and salts, though many ] web applications use regular MD5. The Windows NT/2000 family of windows uses the ] and ] hashing method and is also unsalted, which make it one of the more popularly generated tables.


==External links== ==External links==

Revision as of 16:15, 6 January 2006

A rainbow table is a special type of lookup table that is constructed by placing a plaintext password entry in a chain of keys and cyphertexts, generated by a one-way hash. The end result is a table that contains statistically high chance of revealing a password within a short period of time, generally less than a minute. The success probability of the table depends on the parameters used to generate it. These include the character set used, password length, chain length, table count. Tables are hash specific, e.g. MD5 tables can only crack MD5 hashes. The theory of this technique was first pioneered by Philippe Oechslin as a fast form of time-memory tradeoff (PDF), which he implemented in the Windows password cracker Ophcrack. The more powerful RainbowCrack program was later developed that can generate and use rainbow tables for a variety of character sets and hashing algorithms, including LM hash, MD5, SHA1, etc.

Defense against rainbow tables

A rainbow table is essentially worthless against one-way hashes that include tokens (or salts, in the case of 56-bit DES). For example, if a password hash is generated using the following function (where "." is the concatenation operator):

hash = md5sum(password . token)

...a password cracker would have to generate both every possible token for every possible password — a rainbow table would not give any benefit. However, if a password hash is generated using the following function:

hash = md5sum(password)

...a password cracker may benefit from a rainbow table.

Nearly all distributions and variations of Unix, Linux, and BSD use one-way hashes and salts, though many PHP web applications use regular MD5. The Windows NT/2000 family of windows uses the LAN Manager and NT LAN Manager hashing method and is also unsalted, which make it one of the more popularly generated tables.

External links

Stub icon

This computing article is a stub. You can help Misplaced Pages by expanding it.

Categories:
Rainbow table: Difference between revisions Add topic