Create SHA-512 Hash of a string in Python
Encryption and hashing have served as the foundation for new security modules, among other network security developments. One of the most used hash algorithms is the Secure Hash Algorithm(SHA) with a digest size of 512 bits, or SHA 512.
The SHA-512 hashing algorithm is currently one of the best and secured hashing algorithms after hashes like MD5 and SHA-1 has been broken down. Due to their complicated nature it is not well accepted and SHA-256 is a general standard, but the industry is slowing moving towards this hashing algorithm.
SHA 256 is a part of the SHA 2 family of algorithms, where SHA stands for Secure Hash Algorithm. It was a joint effort between the NSA and NIST to introduce a successor to the weaker SHA 1 family. SHA2 was published in 2001 and has been effective ever since.
The hash function generates the same output hash for the same input string. This means that, you can use this string to validate files or text or anything when you pass it across the network or even otherwise. SHA-512 can act as a stamp or for checking if the data is valid or not.
SHA-512 hasn't gained the popularity that SHA-256 is experiencing or even other types of newer hashing algorithms when it comes to real-world use in blockchain. That being said it does have a few non-blockchain applications that are noteworthy.
The 512 in the name SHA-512 refers to the final hash digest value, meaning that regardless of the amount of plaintext or cleartext, the hash value will always be 512 bits.
For example -
|Input String||Output Hash|
|computer science is amazing! I love it.||d46bc2b8b0e30ee6f2bfe42826a01d550451223e36d8ea73e46f283eeed3514480b16681ebb9ad8d72c7f9247b5711e5f0797578200afe8229abf86b6ade79cd|
SHA-512 hash of a String in Python
SHA-512 hash can be created using the python's default module
hashlib. There are many more hash functions defined in the
The process of creating an SHA-512 hash in python is very simple. First import hashlib, then encode your string that you want to hash i.e., converts the string into the byte equivalent using encode(), then pass it through the
hashlib.sha512() function. We print the
hexdigest value of the hash
m, which is the hexadecimal equivalent encoded string.
Working code example-
import hashlib text = 'Hello!' m = hashlib.sha512(text.encode('UTF-8')) print(m.hexdigest())
Output of the above code-
The value you see here
3a928aa2cc3bf291a4657d1b51e0e087dfb1dea060c89d20776b8943d24e712ea65778fe608ddaee0a191bc6680483ad12be1f357389a2380f660db246be5844 is the SHA-512 hash of the string
The functions used in the above code-
- encode() : Converts the string into bytes to be acceptable by hash function.
- hexdigest() : Returns the encoded data in hexadecimal format.
You can also update the value of the string and check it as well if needed. This can be used to strengthen the hash logic in your workflow where you can append strings in certain order and see if your hash matched the source hash.
import hashlib text = 'Hello!' m = hashlib.sha512() print(m.hexdigest()) m.update(b"Have Fun!") print(m.hexdigest()) m.update(text.encode('UTF-8')) print(m.hexdigest())
Output of the above code-
As you see, the SHA-512 hash of a string using Python is as simple as this code.
The above code just produced SHA512 hash of the string alone, but, to strengthen the security you can also generate SHA512 hash with salt as well.
In case you are looking to create SHA-512 hash of a file or a blob check out this article.
I'm glad that you found the content useful. Happy Coding.