A Comprehensive Evaluation of Cryptographic Algorithms Des 3des Aes Rsa and Blowfish PDF

Download as pdf or txt
Download as pdf or txt
You are on page 1of 8

Available online at www.sciencedirect.

com

ScienceDirect
Procedia Computer Science 78 (2016) 617 – 624

International Conference on Information Security & Privacy (ICISP2015), 11-12 December 2015,
Nagpur, INDIA

A Comprehensive Evaluation of Cryptographic Algorithms: DES,


3DES, AES, RSA and Blowfish
Priyadarshini Patila,*, Prashant Narayankarb,Narayan D G c, Meena S Md
a
Priyadarshini Patil,Department of Information Science & Engineering , BVBCET , Hubli 5800031,India
b
Prashant Narayankar,Department of Information Science & Engineering , BVBCET , Hubli 5800031,India

Abstract

In today’s internet era, with online transactions almost every second and terabytes of data being generated everyday on the
internet, securing information is a challenge. Cryptography is an integral part of modern world information security making the
virtual world a safer place. Cryptography is a process of making information unintelligible to an unauthorized person. Hence,
providing confidentiality to genuine users. There are various cryptographic algorithms that can be used. Ideally, a user needs a
cryptographic algorithm which is of low cost and high performance. However, in reality such algorithm which is a one stop
solution does not exist. There are several algorithms with a cost performance trade off. For example, a banking application
requires utmost security at high cost and a gaming application sending player pattern for analytics does not bother much about
security but needs to be fast and cost effective. Thus, amongst the cryptographic algorithms existing, we choose an algorithm
which best fits the user requirements. In, this process of choosing cryptographic algorithms, a study of strengths, weakness, cost
and performance of each algorithm will provide valuable insights. In our paper, we have implemented and analyzed in detail cost
and performance of popularly used cryptographic algorithms DES, 3DES, AES, RSA and blowfish to show an overall
performance analysis, unlike only theoretical comparisons.
© 2016 The Authors. Published by Elsevier B.V. This is an open access article under the CC BY-NC-ND license
© 2016 The Authors. Published by Elsevier B.V.
(http://creativecommons.org/licenses/by-nc-nd/4.0/).
Peer-reviewunder
Peer-review underresponsibility
responsibility of organizing
of organizing committee
committee of theofICISP2015
the ICISP2015.

Keywords:AES;Blowfish; DES;3DES;RSA;

1. Introduction

In today’s world of gadget addiction, information storage, processing and retrieval are computer based. The

*E-mail address:[email protected]

1877-0509 © 2016 The Authors. Published by Elsevier B.V. This is an open access article under the CC BY-NC-ND license
(http://creativecommons.org/licenses/by-nc-nd/4.0/).
Peer-review under responsibility of organizing committee of the ICISP2015
doi:10.1016/j.procs.2016.02.108
618 Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624

government, judiciary, small to big enterprises and almost every individual is using computer and internet based
services. This puts a huge responsibility on computer scientists and especially information security scientists as the
bad people out there are also evolving fast with technology. With convenience and ease of use provided by
technology, certain risks are posed. We all are very happy with technology at our finger tips on mobiles and
computers. Various online applications like shopping apps, banking apps, social networking apps provide services
round the clock. But if an attacker gets a banking password, money is stolen at the same ease. An attacker may
acquire social media login credentials and use it for mischievous activities. Hence, securing information on
computer, information sent via network, and information residing in applications is necessary. Cryptography is one
such mechanism used in securing information and we will be analyzing cryptographic algorithms in our paper.

2. Related Work
1
Comparison of symmetric and asymmetric cryptography with existing vulnerabilities and countermeasures by
Yogesh Kumar, Rajiv Munjal, and Harsh gives us theoretical comparison of symmetric and asymmetric
cryptography algorithms.2Comparative analysis of performance efficiency and security measures of some encryption
algorithms by AL.Jeeva, V.Palanisamy, K.Kanagaram compares symmetric and asymmetric cryptography
algorithms using parameters key length , tunability ,speed , encryption ratio and security attacks. 3New comparative
study between DES, 3DES and AES within nine factors by Hamdan.O.Alanazi, B.B.Zaidan, .A.Zaidan, Hamid
A.Jalab, M.Shabbir and Y. Al-Nabhani compares DES,3DES and AES algorithms with nine factors key length ,
cipher type, block size, developed year ,cryptanalytic resistance , possible keys, possible ascii keys and time
required to check all possible keys . 4Comparative study of symmetric and asymmetric cryptography techniques by
Ritu Tripathi, Sanjay Agrawal compares symmetric and asymmetric cryptography techniques using throughput, key
length, tunability, speed, encryption ratio and security attacks.5Evaluation of blowfish algorithm based on avalanche
effect by Manisha Mahindrakar gives a new performance measuring metric avalanche effect.

Here, there are theoretical comparisons done but not supported with results and implementations. We have gone
a step ahead and implemented the algorithms and measured performance of an application with respect to
cryptographic strength and system performance in terms of cost and response time. The metrics encryption time and
decryption time tell us the responsiveness of the application. The metrics memory used and number of bits required
to encode optimally to measure cost has not been used in any experiments till now. The metrics entropy and
avalanche effect to measure cryptographic strength and resistance against attacks have also been not used in any
experiments till now. Hence, we have used new metrics in analyzing the performance of the algorithms.

3. Algorithms in our Experiment

3.1. DES

Data Encryption Standard (DES) is a symmetric key block cipher. The key length is 56 bits and block size is 64
bit length. It is vulnerable to key attack when a weak key is used. DES was found in 1972 by IBM using the data
encryption algorithm. It was adopted by the government of USA as standard encryption algorithm. It began with a
64 bit key and then the NSA put a restriction to use of DES with a 56- bit key length, hence DES discards 8 bits of
the 64 bit key and then uses the compressed 56 bit key derived from 64 bit key to encrypt data in block size of 64-
bits .DES can operate in different modes - CBC, ECB, CFB and OFB, making it flexible. It is vulnerable to key
attack when a weak key is used. In 1998 the supercomputer DES cracker, with the help of lakh’s of distributed PCs
on the Internet, cracked DES in 22h.

3.2. 3DES
9
In cryptography, Triple DES is also called Triple Data Encryption Algorithm which is a block cipher. Triple
Data Encryption Standard (3DES) was first published in 1998 which gets its name so because it applies DES cipher
Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624 619

three times to each block of data, Encryption – Decryption – Encryption using DES. The key length is 112 bits or
168 bits and block size is 64 bit length. Because of the increasing computational power available these days and
weak of the original DES cipher, it was subject to brute force attacks and various cryptanalytic attacks; Triple DES
was designed to provide a relatively simple method of increasing the key size of DES to protect against such attacks,
without designing a completely new block cipher algorithm.

3.3. AES
6
Advance Encryption Standard (AES) algorithm was developed in 1998 by Joan Daemen and Vincent Rijmen,
which is a symmetric key block cipher.AES algorithm, supports any combination of data and key length of 128, 192,
and 256 bits. AES allows a 128 bit data length that can be split into four basic operational blocks. These blocks are
considered as array of bytes and organized as a matrix of the order of 4×4 which is also called as state and subject to
rounds where various transformations are done. For full encryption, the number of rounds used is variable N = 10,
12, 14 for key length of 128,192 and 256 respectively. Each round of AES uses permutation and substitution
network, and is suitable for both hardware and software implementation.

3.4. Blowfish
7
Blowfish was first published in 1993 .It is a symmetric key block cipher with key length variable from 32 to 448
bits and block size of 64 bits. Its structure is fiestal network. Blowfish is a symmetric block cipher that can be used
as a informal replacement for DES or IDEA. It takes a variable-length key, from 32 bits to 448 bits, making it ideal
for both domestic and commercial use. Blowfish was designed by Bruce Schneier as a fast, free alternative to
existing encryption algorithms. From then it has been analyzed considerably, and it is slowly gaining popularity as a
robust encryption algorithm. Blowfish is not patented, has free license and is freely available for all uses.

3.5. RSA
8
RSA is founded in 1977 is a public key cryptosystem. RSA is an asymmetric cryptographic algorithm named
after its founders Rivest, Shamir &Adelman. It generates two keys: public key for encryption and private key to
decrypt message .RSA algorithm consist of three steps, step one is key generation which is to be used as key to
encrypt and decrypt data, step two is encryption, where actual process of conversion of plaintext to cipher text is
being carried out and third step is decryption, where encrypted text is converted in to plain text at other side.RSA is
based on factoring problem of finding product of two large prime numbers. Key size is 1024 to 4096 bits.

4. Implementation

We have implemented and compared DES, 3DES, AES, blowfish and RSA. We have implemented the
algorithms in java using Eclipse IDE .We have used packages java security and java crypto .The packages java
crypto and security provides security features like encryption , decryption , key generation , key management
infrastructure , authentication and authorization features. However, blowfish is not provided in java security and
crypto library. We implemented blowfish in java, converted into a jar and added blowfish jar to crypto library
externally. We have used files of sizes 25KB, 50KB, 1MB, 2MB, 3MB consisting of text and images as input for
encryption. The encrypted output of each file is saved as a file, which in turn is input for decryption. For sake of
comparison we have used the same input files for all algorithms throughout the experiment. We have used a same
system for all implementations and analysis work, so that memory and processor conditions remain same for all
algorithms for comparison. All block cipher algorithms are set in a same mode ECB which is default in java crypto
and security.

Java crypto and security package contains the classes and interfaces that implement the Java security architecture.
620 Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624

These classes can be broadly divided into two categories. First, the classes that implements cryptography to perform
operations for information to be transmitted. Second, there is authentication and access control classes that
implement message digests and digital signatures and can authenticate users and other objects. Using the libraries of
this package, we implement various cryptographic algorithms making minor changes in the calling functions. The
method of implementing algorithms using functions of java.security and java.crypto package is as follows: Generate
key using key generator class, create a cipher object with parameters algorithm name and mode, initialize the cipher
created for encryption/decryption and perform encryption/decryption using doFinal() method

5. Evaluation Parameters

Each of the encryption techniques has its own strong and weak points. In order to apply a suitable cryptography
algorithm to an application, we should have knowledge regarding performance, strength and weakness of the
algorithms. Therefore, these algorithms must be analyzed based on several features. In this paper, analysis is done
with following metrics under which the cryptosystems can be compared are described below:

5.1. Encryption time

The time taken to convert plaintext to ciphertext is encryption time. Encryption time depends upon key size,
plaintext block size and mode. In our experiment we have measured encryption time in milliseconds. Encryption
time impacts performance of the system. Encryption time must be less making the system fast and responsive.

5.2. Decryption time

The time to recover plaintext from ciphertext is called decryption time. The decryption time is desired to be less
similar to encryption time to make system responsive and fast. Decryption time impacts performance of system. In
our experiment, we have measured decryption time is milliseconds.

5.3. Memory used

Different encryption techniques require different memory size for implementation. This memory requirement
depends on the number of operations to be done by the algorithm, key size used, initialization vectors used and type
of operations. The memory used impacts cost of the system. It is desirable that the memory required should be as
small as possible.

5.4. Avalanche effect

In cryptography, a property called diffusion reflects cryptographic strength of an algorithm. If there is a small
change in an input the output changes significantly. This is also called avalanche effect. We have measured
Avalanche effect using hamming distance. Hamming distance in information theory is measure of dissimilarity. We
find hamming distance as sum of bit by bit xor considering ascii value, as it becomes easy to implement
programmatically. A high degree of diffusion i.e. high avalanche effect is desired. Avalanche effect reflects
performance of cryptographic algorithm.

Avalanche effect =( hamming distance ÷ file size) (1)

5.5. Entropy

Randomness is an important property in cryptographic processes because information should not be able to be
guessed by an attacker. Entropy is measure of randomness in the information. It measures uncertainty in the
Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624 621

inform
mation. In inform mation security,, we require seccurity algorithm
ms to yield high rrandomness in encrypted
e messsage,
so thaat there is less or
o no dependenccy between key and ciphertext.. With high randdomness, the reelationship betw ween
key an nd ciphertext beecomes complex x. This propertyy is also called confusion. A hhigh degree of confusion
c is dessired
to mak ke it difficult to
o guess to an atttacker. Entropyy reflects perforrmance of crypptographic algorrithm. We calcuulate
entroppy using Shannoon’s formula.

5.6. Number
N of bits reequired for enco
oding optimallyy

Thee number of bits required to encode


e an encryypted characterr should be lesss. Since, the en
ncrypted bit willl be
transm
mitted over a network
n after encoding,
e this metric tell us the bandwidth required for transmission.
t Iff an
encryppted bit is enco
oded with feweer bits, it will consume
c lesserr bandwidth annd also lesser sttorage. Hence, this
impaccts cost.

6. Ressults and Discu


ussions

In this
t section we discuss
d the resu
ults obtained bassed on six evaluuation parameters.

6.1. Encryption
E time

Fig. 1. Encryyption time vs. Filee size for DES, 3DE


ES, AES, Blowfish aand RSA.

Figg. 1. Shows thaat RSA takes hiighest time for encryption, andd blowfish takees least time for encryption, being
fastestt.3DES is a trickk to reuse DES implementation ns by cascadingg three instancess of DES with distinct
d keys. 3D DES
is believed to be secuure up to at leastt "2112" security was designed for
f efficient harddware implemen ntation but it is less
efficieent in software. Blowfish consu umes the least tiime among all. Blowfish is effficient in softwaare, at least on soome
softwaare platforms. It uses key-depeendent lookup tables;
t hence peerformance depends on how th he platform hanndles
memo ory and caches.

6.2. Entropy
E

Table 1. Average entropy values.


v
622 Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624

DES 3DES AES Blowfish RSA


Averagge entropy per bytee of encryption 2.9477 2.9477 3.84024 3.93891 3.0958

Table 1 shows th hat Blowfish sccores highest average


a entropyy per byte of enncryption. Entro
opy is a measurre of
degreee of randomneess of informaation. Randomn ness is an impportant and deesirable propertty of cryptograaphic
algoriithms.AES heav vily uses s box
xes and p boxess, whereas Blow wfish also uses round functionn on s- array annd p-
array. Hence, both AES
A and Blowfissh yield high deegree of random mness in output iinformation, maaking the outputt less
susceeptible to attackss.

6.3. Decryption
D timee

Fig. 2. Decryption time vs. Fille size for DES, 3DE


ES, AES, Blowfishh and RSA.

Fiig. 2. shows thhat all algorithm


ms take less timme for decryptiion than encrypption, RSA tak kes highest timee for
decry
yption, and blowwfish takes leastt time for decry
yption, being fasstest.RSA beingg public key cry
yptosystem usess one
way function which h is hard to inv vert using primme numbers. Thhe use of moduular exponentiaation, multiplicative
inversse and two keyss public and priv
vate key makes RSA slow com mpared to symm metric key algoritthms.

6.4. Memory
M Used

Table 2.
2 Comparison of memory
m used.
Algorrithm Memoory
Used((KB)
DES 18.2
Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624 623

3DES 20.7
AES 14.7
Blowffish 9.38
RSA 31.5

Taable 2 shows th hat memory used for unit opeerations for listeed algorithms. Blowfish consu umes least mem
mory
whereeas RSA consum mes highest meemory per unitt of operation.D DES and AES require medium m size of mem
mory.
Thereffore, if the demand of any appllication is the sm
mallest memoryy size the Blowffish is the best option.
o

6.5. Avalanche Effectt

Fig. 3. Avalanche effecct for DES, 3DES, AES,


A Blowfish and RSA.

Fiig.3. Shows thhat AES exhibiits highest Avaalanche effect whereas RSA exhibits least Avalanche eff ffect.
Avalan nche effect tells us the degreee of diffusion n of information .A change oof one bit in plaintext
p leadingg to
signifiicant change inn bits of output information.AE ES uses a substtitution permutaation network using
u multiplicaative
inversse and affine tran
nsformations ovver a galois field leading to higgh mixing of infformation leadin
ng to high diffuusion
in outpput.

6.6. Number
N of bits reequired to encode optimally

Table 3. Optimal encodingg length


DES 3DES AES Blowfish RSA
Averagee number of bits reqquired to 27 40 256 128 44
optimallly encode a byte off encrypted data
624 Priyadarshini Patil et al. / Procedia Computer Science 78 (2016) 617 – 624

Table 3 shows that AES requires highest number of bits to be encoded optimally an encrypted data and DES
requires least number of bits to be encoded optimally, indicating AES requires highest bandwidth for transmission.

7. Conclusion

Each of the encryption techniques has its own strong and weak points. In order to apply a suitable cryptography
algorithm to an application, we should have knowledge regarding performance, strength and weakness of the
algorithms. From the experiment results, it is evident that the memory required for implementation is smallest in
blowfish whereas it is largest in RSA. DES and AES require medium size of memory. Therefore, if the demand of
any application is the smallest memory size the Blowfish is the best option; Results shows that RSA consumes more
time for encryption and decryption compared to others. Blowfish consumes the least time amongst all. Blowfish is
efficient in software, at least on some software platforms. After evaluating algorithms based on parameter
Avalanche effect AES scores highest; we can conclude that AES can be used in applications where confidentiality
and integrity is of highest priority. Evaluating DES, 3DES, AES, Blowfish and RSA based on parameters entropy,
Blowfish scores highest; hence we can conclude that Blowfish is strongest against guessing attacks. Results shows
that AES requires highest number of bits to be encoded optimally an encrypted data and DES requires least number
of bits to be encoded optimally, indicating AES requires highest bandwidth for transmission. If time and memory is
a major factor in the application, Blowfish is the best suited algorithm. If cryptographic strength is a major factor in
the application, AES is the best suited algorithm. If network bandwidth is a major factor in the application; DES is
the best suited algorithm. We can evaluate other cryptographic techniques on similar lines considering other
performance metrics and implement the best-fit algorithm for a targeted application.

References

1.Comparison of symmetric and asymmetric cryptography with existing vulnerabilities and countermeasures byYogesh Kumar, Rajiv Munjal,
and Harsh ,(IJAFRC) Volume 1, Issue 6, June 2014. ISSN 2348 - 4853
2.Comparative analysis of performance efficiency and security measures of some encryption algorithms by AL.Jeeva, Dr.V.Palanisamy,
K.Kanagaram compares symmetric and asymmetric cryptography algorithms ISSN: 2248-9622
3. New Comparative Study Between DES, 3DES and AES within Nine Factors Hamdan.O.Alanazi, B.B.Zaidan, . A.Zaidan, Hamid A.Jalab,
M.Shabbir and Y. Al-Nabhani JOURNAL OF COMPUTING, VOLUME 2, ISSUE 3, MARCH 2010, ISSN 2151-9617
4. Comparative Study of Symmetric and Asymmetric Cryptography Techniques by Ritu Tripathi, Sanjay Agrawal compares Symmetric and
Asymmetric Cryptography Techniques using throughput, key length, tunability, speed, encryption ratio and security attacks. IJCSMS
International Journal of Computer Science and Management Studies, Vol. 11, Issue 03, Oct 2011 ISSN (Online): 2231-5268
5. Evaluation of Blowfish Algorithm based on Avalanche Effect by Manisha Mahindrakar gives a new performance measuring metric avalanche
effect. International Journal of Innovations in Engineering and Technology (IJIET) 2014
6. Efficient Implementation of AES, RituPahal, Vikaskumar, Volume 3, Issue 7, July 2013 ISSN: 2277 128X, © 2013, IJARCSSE
7. Superiority of blowfish Algorithm ,Pratap Chandra Mandal , Volume 2, Issue 9, September 2012 ISSN: 2277 128X International Journal of
Advanced Research in Computer Science and Software Engineering
8. A study and performance of RSA algorithm, IJCSMC, Vol. 2, Issue. 6, June 2013, pg.126 – 139, ISSN 2320– 088X
9. Data encryption and decryption by using triple DES and performance analysis of crypto system, Karthik .S ,Muruganandam .A, ISSN
(Online): 2347-3878 Volume 2 Issue 11, November 2014

You might also like