Table of Content

Key Management Interoperability Protocol

What is SHA? What is SHA used for?

What is SHA? What is SHA used for?

Introduction to SHA

SHA stands for secure hashing algorithm. SHA is a modified version of MD5 and used for hashing data and certificates. A hashing algorithm shortens the input data into a smaller form that cannot be understood by using bitwise operations, modular additions, and compression functions. You may be wondering, can hashing be cracked or decrypted?

Hashing is similar to encryption, the only difference between hashing and encryption is that hashing is one-way, meaning once the data is hashed, the resulting hash digest cannot be cracked, unless a brute force attack is used. See the image below for the working of SHA algorithm. SHA works in such a way even if a single character of the message changed, then it will generate a different hash. For example, hashing of two similar, but different messages like, Heaven and heaven are different, however, there is only a difference of a capital and small letter.

SHA

 The initial message is hashed with SHA-2, resulting in the hash digest “06b73bd57b3b938786daed820cb9fa4561bf0e8e”. If the second, similar, message is hashed with SHA-2, the hash digest will look like “66da9f3b8d9d83f34770a14c38276a69433a535b”. This is referred to as the avalanche effect. This effect is important in cryptography, as it means even the slightest change in the input message completely changes the output. This will stop attackers from being able to understand what the hash digest originally said and telling the receiver of the message whether or not the message has been changed while in transit.

SHAs also assist in revealing if an original message was changed in any way. By referencing the original hash digest, a user can tell if even a single letter has been changed, as the hash digests will be completely different. One of the most important parts of SHAs are that they are deterministic. This means that as long as the hash function used is known, any computer or user can recreate the hash digest. The determinism of SHAs is one of reasons every SSL certificate on the Internet is required to have been hashed with a SHA-2 function.

Different SHA Forms

When learning about SHA forms, several different types of SHA are referenced. Examples of SHA names used are SHA-1, SHA-2, SHA-256, SHA-512, SHA-224, and SHA-384, but in actuality there are only two types: SHA-1 and SHA-2. The other larger numbers, like SHA-256, are just versions of SHA-2 that note the bit lengths of the SHA-2. SHA-1, introduced in 1993, was the original secure hashing algorithm, returning a 160-bit hash digest after hashing.

However, due to its short bit length, vulnerabilities like collision attacks surfaced. In cryptography, a collision occurs when two different inputs produce the same hash. Over time, it became easier to find these collisions, significantly undermining SHA-1’s security. A landmark event was the 2017 “SHAttered” attack conducted by Google and CWI researchers, which successfully demonstrated a collision in SHA-1, marking its obsolescence in secure applications. SHA-1 is now a deprecated algorithm, no longer used for hashing online.

Someone may wonder, can SHA-2 be cracked like SHA-1? The answer is yes. Due to the short length of the hash digest, SHA-1 is more easily brute-forced than SHA-2, but SHA-2 can still be brute-forced. SHA-1 can give the same hash digest to two different values, as the number of combinations that can be created with 160 bits is so small. SHA-2 on the other hand gives every digest a unique value, which is why all certificates are required to use SHA-2. SHA-2 can produce a variety of bit-lengths, from 256 to 512 bit, allowing it to assign completely unique values to every hash digest created.  

The industry began transitioning to SHA-2 in the early 2000s, though the full migration took time. SHA-2, with its larger bit lengths (e.g., 256-bit and 512-bit), offered stronger security against collisions and brute force attacks. By 2016, most major systems had phased out SHA-1 in favor of SHA-2, but resistance and challenges persisted during the transition.

Many organizations were slow to adopt SHA-2 due to the need for significant infrastructure updates, including upgrading legacy systems, ensuring compatibility with older hardware and software, replacing outdated certificates, and reconfiguring security protocols to support the stronger encryption standard. Despite the delay, SHA-256 became the new standard, especially for SSL/TLS certificates and digital signatures, providing better resistance to cryptographic attacks. 

Compared to SHA-1, SHA-2 is much more secure and has been required in all digital signatures and certificates since 2016. Common attacks like brute force attacks can take years or even decades to crack the hash digest, so SHA-2 is considered the most secure hash algorithm. 

What is SHA used for?

As previously mentioned, Secure Hashing Algorithms are required in all digital signatures and certificates relating to SSL/TLS connections, but there are more uses to SHAs as well. Applications such as SSH, S-MIME (Secure / Multipurpose Internet Mail Extensions), and IPSec utilize SHAs as well.  SHAs are also used to hash passwords so that the server only needs to remember hashes rather than passwords.

In this way, if an attacker steals the database containing all the hashes, they would not have direct access to all of the plaintext passwords, they would also need to find a way to crack the hashes to be able to use the passwords. SHAs can also work as indicators of a file’s integrity. If a file has been changed in transit, the resulting hash digest created from the hash function will not match the hash digest originally created and sent by the file’s owner.

In blockchain technology, particularly in cryptocurrencies like Bitcoin, SHA-256 plays a crucial role. It is integral to the mining process, where it helps solve complex mathematical puzzles to validate and add new transactions to the blockchain. 

Key Reasons to use SHA

We have now learned what SHAs are used for, but why use a Secure Hashing Algorithm in the first place? A common reason is their ability to stop attackers. Though some methods, like brute force attacks, can reveal the plaintext of the hash digests, these tactics are made extremely difficult by SHAs. A password hashed by a SHA-2 can take years, even decades to break, thus wasting resources and time on a simple password, which may turn many attackers away.

Another reason to use SHAs is the uniqueness of all the hash digests. If SHA-2 is used, there will likely be few to no collisions, meaning a simple change of one word in a message would completely change the hash digest. Since there are few or no collisions, a pattern cannot be found to make breaking the Secure Hashing Algorithm easier for the attacker. These are just a few reasons why SHA is used so often.

SHA 2 Limitations

  • Browser Support
BrowserMinimum Browser Version
Chrome26+
Firefox1.5+
Internet Explorer6+ (With XP SP3+)
Netscape7.1+
Safari3+ (Ships with OS X 10.5)
Mozilla1.4+
Opera9.0+
  • Server Support
ServerMinimum Server Version
AWS (Amazon Web Services)YES
Apache2.0.63+ w/ OpenSSL 0.9.8o+
Cisco ASA 55008.2.3.9+ for AnyConnect VPN Sessions; 8.4(2)+ for other functionalities
Java based productsJava 1.4.2+
IBM Domino Server9.0+ (Bundled with HTTP 8.5+)
IBM HTTP Server8.5+ (Bundled with Domino 9+)
IBM z/OSv1r10+
OpenSSL based productsOpenSSL 0.9.8o+
Oracle Wallet Manager11.2.0.1+
Oracle Weblogic10.3.1+
Web Sphere MQ7.0.1.4+
  • OS Support
Operating SystemSSL Certificate Minimum OS VersionClient Certificate Minimum OS Version
Android2.3+2.3+
iOS3.0+3.0+
ChromeOSYESYES
Mac OS X10.5+10.5+
Windows XPSP3+ XPSP3+ (partial)
Windows Server2003 SP2 +Hotfixes (Partial)2003 SP2 +Hotfixes (Partial)
Windows Phone7+7+
Blackberry5.0+5.0+

The Future of Hashing

At this point in time, SHA-2 is the industry standard for hashing algorithms, though SHA-3 may eclipse this in the future. SHA-3 was released by the NIST, which also created SHA-1 and SHA-2, in 2015 but was not made the industry standard for many reasons. During the release of SHA-3, most companies were in the middle of migrating from SHA-1 to SHA-2, so switching right on to SHA-3 while SHA-2 was still very secure did not make sense.

Along with this, SHA-3 was seen as slower than SHA-2, although this is not exactly the case. SHA-3 is slower on the software side, but it is much faster than SHA-1 and SHA-2 on the hardware side, and is getting faster every year. For these reasons, we will likely see the move to SHA-3 later on down the line, once SHA-2 becomes unsafe or deprecated.

Conclusion

Secure Hashing Algorithm, is a pivotal tool in modern cryptography, transforming input data into unique and irreversible hash digests. Unlike encryption, hashing is one-way, rendering it resistant to decryption except through brute force methods. SHA variants, notably SHA-1 and SHA-2, serve crucial roles in digital security, with SHA-2 being the preferred choice due to its enhanced resistance to brute force attacks and collision vulnerabilities.

How can Encryption Consulting help? 

With a strong focus on Encryption Advisory services and decades of consulting expertise, Encryption Consulting offers a range of cryptographic solutions. Among these, PKI as a Service (PKIaaS) stands out, providing round-the-clock support to clients for any issues related to their PKI environment. This comprehensive approach enhances security, ensuring organizations remain resilient against potential misconfigurations in their encryption setups.

Explore the full range of services offered by Encryption Consulting.

Feel free to schedule a demo to gain a comprehensive understanding of all the services Encryption Consulting provides.

Request a demo