School of Computer Science and Engineering Fall Semester 2020-21
School of Computer Science and Engineering Fall Semester 2020-21
School of Computer Science and Engineering Fall Semester 2020-21
2020-21
Lab Assessment -2
Securing information with strong Symmetric encryption algorithm
While security is an afterthought for many PC users, it’s a major priority for businesses of any size.
There are many researches and evidences tell us that security breaches are costing companies
millions every year. Encryption is an interesting piece of technology that works by scrambling data so
it is unreadable by unintended parties.
For example, to send someone a private message, we encrypt it using either one of these programs.
Once encrypted, the message literally becomes a jumbled mess of random characters. But, equipped
with the secret passcode we can send the text, receiver can decrypt it and find the original message.
The technology comes in many forms, with key size and strength generally being the biggest
differences in one variety from the next.
1. Triple DES
Triple DES was designed to replace the original Data Encryption Standard (DES) algorithm, which
hackers eventually learned to defeat with relative ease. At one time, Triple DES was the
recommended standard and the most widely used symmetric algorithm in the industry.
Triple DES uses three individual keys with 56 bits each. The total key length adds up to 168 bits, but
experts would argue that 112-bits in key strength is more like it.
Despite slowly being phased out, Triple DES still manages to make a dependable hardware
encryption solution for financial services and other industries.
2. RSA
RSA is a public-key encryption algorithm and the standard for encrypting data sent over the internet.
It also happens to be one of the methods used in our PGP and GPG programs.
Unlike Triple DES, RSA is considered an asymmetric algorithm due to its use of a pair of keys. You’ve
got your public key, which is what we use to encrypt our message, and a private key to decrypt it.
The result of RSA encryption is a huge batch of mumbo jumbo that takes attackers quite a bit of time
and processing power to break.
3. Blowfish
Blowfish is yet another algorithm designed to replace DES. This symmetric cipher splits messages
into blocks of 64 bits and encrypts them individually.
Blowfish is known for both its tremendous speed and overall effectiveness as many claim that it has
never been defeated. Meanwhile, vendors have taken full advantage of its free availability in the
public domain.
Blowfish can be found in software categories ranging from e-commerce platforms for securing
payments to password management tools, where it used to protect passwords. It’s definitely one of
the more flexible encryption methods available.
4. Twofish
Computer security expert Bruce Schneier is the mastermind behind Blowfish and its
successor Twofish. Keys used in this algorithm may be up to 256 bits in length and as a symmetric
technique, only one key is needed.
Twofish is regarded as one of the fastest of its kind, and ideal for use in both hardware and software
environments. Like Blowfish, Twofish is freely available to anyone who wants to use it. As a result,
you’ll find it bundled in encryption programs such as PhotoEncrypt, GPG, and the popular open
source software TrueCrypt.
5. AES
The Advanced Encryption Standard (AES) is the algorithm trusted as the standard by the U.S.
Government and numerous organizations.
Although it is extremely efficient in 128-bit form, AES also uses keys of 192 and 256 bits for heavy
duty encryption purposes.
AES is largely considered impervious to all attacks, with the exception of brute force, which attempts
to decipher messages using all possible combinations in the 128, 192, or 256-bit cipher. Still, security
experts believe that AES will eventually be hailed the de facto standard for encrypting data in the
private sector
Implementing AES
AES CIPHER:
byte = 8 bits)
print(key)
key =b'\xb1\xd0x\x12IT\x07\xcd\x8e\x1dB\xfd\x80l\x0c\x05'
cipher = AES.new(key, AES.MODE_EAX) # EAX mode
ciphered_data
original_data = cipher.decrypt_and_verify(ciphered_data,
tag)
original_data
OUTPUT:
Implementing BLOWFISH
from Crypto.Random import
get_random_bytes key =
get_random_bytes(32)
print(key)
b'Q\xb3\xacN!f+\x07b'\x82\x0c\x06LE\xef4a\xd1\xbd\xfa\xe6n\x88X\x7f*x\xe6\n)Tt(V\x8a0I\x11>
S2'
OUTPUT:
Email Server configuration
in Cisco Packet Tracer
Server:
Router:
PC:
Sender’s side (PC1):