Internet Security - Hashing Algorithms
29 Questions
0 Views

Choose a study mode

Play Quiz
Study Flashcards
Spaced Repetition
Chat to lesson

Podcast

Play an AI-generated podcast conversation about this lesson

Questions and Answers

What is the primary purpose of using a salt when hashing passwords?

  • To store passwords in an encrypted format.
  • To ensure that identical passwords have different hashes. (correct)
  • To speed up the hashing process.
  • To simplify the password retrieval process.
  • Which attack method involves trying every possible combination of characters?

  • Rainbow table attack
  • Brute force attack (correct)
  • Dictionary attack
  • Hash table lookup
  • Which of the following is a characteristic of rainbow tables?

  • They are pre-computed for cryptographic hash functions. (correct)
  • They are faster than hash table lookups.
  • They use a reverse-lookup approach for cracking passwords.
  • They require no prior knowledge of the password hash.
  • What should a system display when a user fails to log in?

    <p>Invalid username or password.</p> Signup and view all the answers

    What does a hash collision indicate in cryptography?

    <p>Two different inputs produce the same hash output.</p> Signup and view all the answers

    What is the main purpose of hashing algorithms in internet security?

    <p>To provide data integrity assurance</p> Signup and view all the answers

    What is a characteristic of a cryptographically strong hash function?

    <p>It is impossible to recover input data from its digest</p> Signup and view all the answers

    Which of the following statements about MD5 is true?

    <p>It is popular for internet applications</p> Signup and view all the answers

    When hashing a password during account creation, what happens to the cleartext password?

    <p>It is discarded after hashing and never stored</p> Signup and view all the answers

    How does SHA-1 compare to MD5 in terms of performance?

    <p>MD5 is slightly faster than SHA-1</p> Signup and view all the answers

    What is the output length of a SHA-1 hash?

    <p>160 bits</p> Signup and view all the answers

    What does 'collision resistance' mean in the context of hashing algorithms?

    <p>No two different inputs will produce the same hash</p> Signup and view all the answers

    Which hashing algorithm produces a 128-bit digest?

    <p>MD5</p> Signup and view all the answers

    What is the main purpose of hashing?

    <p>To ensure the authenticity and integrity of messages</p> Signup and view all the answers

    Which statement correctly differentiates between encryption and hashing?

    <p>Encryption can be reversed to obtain the original plaintext.</p> Signup and view all the answers

    What role does adding salt play in hashing?

    <p>It decreases the risk of hash collisions.</p> Signup and view all the answers

    What is a defining characteristic of hash functions?

    <p>They can handle any block of data size.</p> Signup and view all the answers

    What is the significance of a Hash-based Message Authentication Code (HMAC)?

    <p>It combines a hash function with a MAC for added security.</p> Signup and view all the answers

    Which of the following describes what non-repudiation in hashing ensures?

    <p>The sender cannot deny sending the message.</p> Signup and view all the answers

    Which property should a hash function ideally have?

    <p>It should produce outputs that vary dramatically with similar inputs.</p> Signup and view all the answers

    What does the term 'message integrity' refer to in the context of hashing?

    <p>It allows verification that the message was sent by an authentic source.</p> Signup and view all the answers

    What is the primary vulnerability of MD5 that limits its current use?

    <p>It can be broken on a single notebook within minutes.</p> Signup and view all the answers

    Which of the following hashing functions produces a 160-bit hash value?

    <p>SHA-1</p> Signup and view all the answers

    In the context of hash algorithms, what does 'collision' refer to?

    <p>Two messages that result in the same hash value.</p> Signup and view all the answers

    What is the purpose of a Message Authentication Code (MAC)?

    <p>To verify the identity of the sender.</p> Signup and view all the answers

    Which hashing algorithm is recommended for current use?

    <p>SHA-256</p> Signup and view all the answers

    What is a common characteristic of all secure hash algorithms?

    <p>They should be resistant to the birthday attack.</p> Signup and view all the answers

    What does HMAC stand for?

    <p>Hash-based Message Authentication Code</p> Signup and view all the answers

    How many rounds does SHA-1 perform when computing a hash value?

    <p>20 rounds</p> Signup and view all the answers

    Study Notes

    Internet Security - Hashing Algorithms

    • Hashing algorithms are used for data integrity assurance
    • They are based on one-way mathematical functions
    • Input data produces a fixed-length digest (fingerprint) of output data
    • Digests are cryptographically strong; recovering original data from the digest is impossible
    • Well-known hash functions include:
      • Message Digest 5 (MD5) – 128 bits digest
      • Secure Hash Algorithm 1 (SHA-1) – 160 bits digest

    Key Hash Functions

    • MD5 (Message Digest 5):

      • Computes a 128-bit hash value
      • Widely used for file integrity checking
      • Based on MD4, addressing vulnerabilities in MD4
      • Generates 128-bit hash values over 512-bit blocks in 4 rounds of 16 steps each
    • SHA-1 (Secure Hash Algorithm 1):

      • Computes a 160-bit hash value
      • An NIST approved message digest algorithm
      • Operates on 512-bit blocks, producing a 160-bit hash value in 4 rounds of 20 steps each
    • MD5:
      • Designed by Ron Rivest in 1991
      • 128-bit output (considered too short for current use)
      • Developed in 2005
      • Can be broken on a single notebook within minutes
    • SHA:
      • Designed by the NSA, published in 1993
      • Family of functions: SHA-1, SHA-224, SHA-256, SHA-384, SHA-512
      • SHA-256 is the current recommendation

    Birthday Attack

    • Collisions: Two messages with the same hash value
    • Based on the birthday paradox
    • Hash algorithms should resist this attack
    • Each input generates a unique digest

    Hash Collision

    • Hash functions map arbitrary amounts of data into fixed-length strings
    • Due to the nature of fixed output lengths, some inputs inevitably hash into the same string
    • Cryptographic hash functions are designed to make these collisions difficult to find

    Password Hashing

    • Account creation and password hashing involves hashing the password to store it in the database
    • Never store cleartext passwords
    • The attempted password is hashed and compared to the hash of the original password (stored in the password file).
    • Users gain access only if the hashes match.
    • Never give user password/username error specific messages.

    How to crack Hashed Passwords

    • Dictionary attacks: Uses a file containing common passwords (words, phrases). A file of potential words/phrases is hashed. Its hash is compared to the victim's credential hash
    • Brute force attacks: Tries every possible combination of characters up to a given length
    • Hash table lookup: Precomputing the hashes of the passwords (in a dictionary). Store hashes and associated passwords. Faster than rainbow tables but needs significant storage
    • Reverse-lookup table: Obtaining a user's password and hash. Determine the algorithm and apply the lookup to all other accounts
    • Rainbow table: Pre-computed table for reversing cryptographic hash functions (usually for cracking passwords). Efficient way to store a pre-computed hash but is slower than lookup

    Adding Salt

    • Lookup tables and rainbow tables work when a password is hashed exactly the same way
    • Randomize hashes by appending or prepending a random string (salt) to the password before hashing

    Encryption vs Hashing

    Feature Encryption Hashing
    Use of Key Uses a key Key is added to the text; combination is hashed
    Length of Result Output is similar in length to input Output is of a fixed short length, regardless of input
    Reversibility Reversible (ciphertext can be decrypted to plaintext) One-way function; cannot be "de-hashed" back to the original string

    Purpose of Hashing

    • Non-repudiation: Cannot deny what has been sent
    • Detect doctored messages: Original messages are compared to their digests
    • Messages and their digests are sent together for verification
    • Salt can decrease the risk of hash collision

    Terminology

    • Message encryption: Ciphertext of entire message serves as authenticator
    • Message authentication code (MAC): Public function of message and secret key that produces a fixed length value that serves as authenticator
    • Hash function: A public function that maps a message of any length into a fixed length hash value that serves as authenticator
    • Hash-based Message Authentication Code (HMAC): Combination of hash function and MAC using a shared secret

    Message Integrity

    • Allows verification of received messages' authenticity
    • Ensures message content hasn't been altered
    • Checks source of message and its temporal integrity
    • Maintains sequence of messages

    Formal Requirements of Hash Function

    • H() can be applied to any block of data of any size
    • H() produces a fixed-length output
    • H(x) is relatively easy to compute for any given x
    • One-way property: Very difficult to find another input (X') on which H(X) = H(X')
    • Weak collision resistance: Given an input X and a hashing function H(), it is very difficult to find another input X' on which H(X) = H(X')
    • Strong collision resistance: H() and two arbitrary inputs (X & Y), a low probability of H(X) being equal to H(Y)

    Other Important Details

    • Hash is used in digital signatures with analogous techniques to handwritten signatures for verifiability and non-forgeability.
    • HMAC is a popular MAC standard addressing subtle security flaws in MAC calculation.

    Studying That Suits You

    Use AI to generate personalized quizzes and flashcards to suit your learning preferences.

    Quiz Team

    Related Documents

    Description

    Explore the essential concepts of hashing algorithms, including their role in data integrity assurance and cryptographic security. Delve into popular hash functions like MD5 and SHA-1, their characteristics, and applications. Understand how these algorithms function and the significance of their fixed-length digests.

    More Like This

    Image Details Entry
    18 questions

    Image Details Entry

    LongLastingEvergreenForest avatar
    LongLastingEvergreenForest
    Hashing Algorithms in Data Security
    18 questions
    COS 212 Hashing and Searching Algorithms
    10 questions
    Cryptography and Hashing Algorithms
    63 questions
    Use Quizgecko on...
    Browser
    Browser