IT8761-Security Lab Manual
IT8761-Security Lab Manual
IT8761-Security Lab Manual
COLLEGE
(An Autonomous Institution)
SRM Nagar, Kattankulathur-603203.
LAB MANUAL
( REGULATION - 2017 )
SEVENTH SEMESTER
PREPARED BY
d MODE OF ASSESSMENT 9
6 DIFFIEE-HELLMAN 59-61
7 SHA 62-65
2
PROGRAMME EDUCATIONAL OBJECTIVES (PEOs)
1. To afford the necessary background in the field of Information Technology to deal with engineering
problems to excel as engineering professionals in industries.
2. To improve the qualities like creativity, leadership, teamwork and skill thus contributing towards the
growth and development of society.
3. To develop ability among students towards innovation and entrepreneurship that caters to the needs
of Industry and society.
4. To inculcate and attitude for life-long learning process through the use of information technology
sources.
5. To prepare then to be innovative and ethical leaders, both in their chosen profession and in other
activities.
3
Apply reasoning informed by the contextual knowledge to
assess societal, health, safety, legal, and cultural issues and the
6 The engineer and society
consequent responsibilities relevant to the professional
engineering practice
Understand the impact of the professional engineering solutions
Environment and
7 in societal and environmental contexts, and demonstrate the
sustainability
knowledge of, and need for sustainable development.
Apply ethical principles and commit to professional ethics and
8 Ethics
responsibilities and norms of the engineering practice
Function effectively as an individual, and as a member or
9 Individual and team work
leader in diverse teams, and in multidisciplinary settings
Communicate effectively on complex engineering activities
with the engineering community and with the society at large,
10 Communication such as, being able to comprehend and write effective reports
and design documentation, make effective presentations, and
give and receive clear instructions
Demonstrate knowledge and understanding of the engineering
Project management and and management principles and apply these to one’s own work,
11
finance as a member and leader in a team, to manage projects and in
multidisciplinary environments
Recognize the need for, and have the preparation and ability to
4
PROGRAM SPECIFIC OUTCOMES (PSOs)
By the completion of Information Technology program the student will have following Program
specific outcomes
1. Design secured database applications involving planning, development and maintenance using
state of the art methodologies based on ethical values.
2. Design and develop solutions for modern business environments coherent with the advanced
technologies and tools.
3. Design, plan and setting up the network that is helpful for contemporary business environments
using latest hardware components.
4. Planning and defining test activities by preparing test cases that can predict and correct errors
ensuring a socially transformed product catering all technological needs.
5
SYLLABUS
LIST OF EXPERIMENTS:
1. Perform encryption, decryption using the following substitution techniques
i. Ceaser cipher
ii. Playfair cipher
iii. Hill Cipher
iv. Vigenere cipher
2. Perform encryption and decryption using following transposition techniques
Rail fence - Row & Column Transformation
3. Apply DES algorithm for practical applications.
4. Apply AES algorithm for practical applications
5. Implement RSA Algorithm using HTML and JavaScript
6. Implement the Diffie-Hellman Key Exchange algorithm for a given problem.
7. Calculate the message digest of a text using the SHA-1 algorithm
8. Implement the SIGNATURE SCHEME - Digital Signature Standard.
9. Demonstrate intrusion detection system (ids) using any tool eg. Snort or any other s/w.
10. Automated Attack and Penetration Tools Exploring N-Stalker, a Vulnerability Assessment
Tool
11. Defeating Malware - Building Trojans, Rootkit Hunter
TOTAL: 60 PERIODS
6
LIST OF EQUIPMENT FOR A BATCH OF 30 STUDENTS:
SOFTWARE:
C / C++ / Java or equivalent compiler
GnuPG, Snort, N-Stalker or Equivalent
HARDWARE:
Standalone desktops - 30 Nos. (or) Server supporting 30 terminals or more.
OUTCOMES:
At the end of the course, the student should be able to
7
COURSE OUTCOMES:
IT8761.1 An Ability to develop code for classical Encryption Techniques to solve the problems.
An Ability to Build cryptosystems by applying symmetric and public key encryption
IT8761.2
algorithms
IT8761.3 An Ability to Construct code for authentication algorithms.
IT8761.5 An Ability to Demonstrate the network security system using open source tools
CO-PO MATRIX:
CO PO1 PO2 PO3 PO4 PO5 PO6 PO7 PO8 PO9 PO10 PO11 PO12
IT8761.1 3 - 3 - - - - - - - - -
IT8761.2 - 3 - - - - - - - - - -
IT8761.3 - 3 3 - - - - - - - - -
IT8761.4 - - - 2 - - - - - - - -
IT8761.5 - - - 2 - 3 - - - - - -
IT8761 3 3 3 2 - 3 - - - - - -
CO-PSO MATRIX:
CO PSO2
IT8761.1 2
IT8761.2 2
IT8761.3 2
IT8761.4 2
IT8761.5 2
IT8761 2
8
MODE OF ASSESSMENT
2. Observation 20
5. Viva 20
Total 100
2. Record 5
3. Model Test 5
Total 20
9
DESCRIPTION OF MAJOR SOFTWARE USED
JAVA
Installation requires you to download an executable file available at the manual Java
download page, which includes all the files needed for the complete installation at the user's
discretion. There is no need to remain connected to the Internet during the installation. The file can
also be copied to and installed on another computer that is not connected to the Internet.
Administrative permission is required in order to install Java on Microsoft Windows
The Java syntax is similar to C++, but is strictly an object-oriented programming language.
For example, most Java programs contain classes, which are used to define objects, and methods,
which are assigned to individual classes. Java is also known for being more strict than C++, meaning
variables and functions must be explicitly defined. This means Java source code may produce errors
or "exceptions" more easily than other languages, but it also limits other types of errors that may be
caused by undefined variables or unassigned types.
Unlike Windows executables (.EXE files) or Macintosh applications (.APP files), Java
programs are not run directly by the operating system. Instead, Java programs are interpreted by the
Java Virtual Machine, or JVM, which runs on multiple platforms. This means all Java programs are
multiplatform and can run on different platforms, including Macintosh, Windows, and Unix
computers. However, the JVM must be installed for Java applications or applets to run at all.
Fortunately, the JVM is included as part of the Java Runtime Environment (JRE), which is available
as a free download.
SNORT
Snort really isn’t very hard to use, but there are a lot of command line options to play with,
and it’s not always obvious which ones go together well. This file aims to make using Snort easier for
new users. Before we proceed, there are a few basic concepts you should understand about Snort.
Snort can be configured to run in three modes:
•Sniffer mode, which simply reads the packets off of the network and displays them for you in
a continuous stream on the console (screen).
•Network Intrusion Detection System (NIDS) mode, which performs detection and analysis
on network traffic. This is the most complex and configurable mode.
10
Snort is based on libpcap (for library packet capture), a tool that is widely used in TCP/IP
traffic sniffers and analyzers. Through protocol analysis and content searching and matching, Snort
detects attack methods, including denial of service, buffer overflow, CGI attacks, stealth port scans,
and SMB probes
N-STALKER
N-STALKER is a world leader in Web Application Security solutions since 2000. It has
started providing the first commercial and most complete HTTP Security Scanner, holding the largest
signatures database available in the market – more than 39,000 attack signatures. Our products are
delivered to hundreds of customers distributed in more than 30 different countries around the world.
Back in 2000, N-Stalker’s challenge was to provide complete solutions for your Web server
infrastructure, which ended up with the release of N-Stealth HTTP Security Scanner. Nowadays, N-
Stalker is seeking to provide the most complete solution for your enterprise web applications, the N -
Stalker Web Application Security Scanner Suite.
11
EX.No.:1(a) CAESAR CIPHER
AIM:
To implement a program for encrypting a plain text and decrypting a cipher text using Caesar
Cipher (shift cipher) substitution technique
PRELAB DISCUSSION:
The Caesar cipher is one of the earliest known and simplest ciphers. It is a type of substitution
cipher in which each letter in the plaintext is 'shifted' a certain number of places down the alphabet.
For example, with a shift of 1, A would be replaced by B, B would become C, and so on. The method
is named after Julius Caesar, who apparently used it to communicate with his generals. More complex
encryption schemes such as the Vigenere employ the Caesar cipher as one element of the encryption
process. The widely known ROT13 'encryption' is simply a Caesar cipher with an offset of 13. The
Caesar cipher offers essentially no communication security, and it will be shown that it can be easily
broken even by hand.
To pass an encrypted message from one person to another, it is first necessary that both parties
have the 'key' for the cipher, so that the sender may encrypt it and the receiver may decrypt it. For the
caesar cipher, the key is the number of characters to shift the cipher alphabet.
First we translate all of our characters to numbers, 'a'=0, 'b'=1, 'c'=2, ... , 'z'=25. We can now
represent the caesar cipher encryption function, e(x), where x is the character we are encrypting, as:
Where k is the key (the shift) applied to each letter. After applying this function the result is a number
which must then be translated back into a letter. The decryption function is :
ALGORITHM:
1. Create and initialize a string ALPHABET that holds the alphabet characters. The index
position of the string represents the numeric representation for the corresponding characters in
the string ALPHABET.
2. Read the input plain text to be encrypted and also the Caeser cipher key an integer between 0
and 25.
3. Encrypt the plain text using the Caeser cipher key and the ALPHABET string.
a. For every character in the plain text
i. Search the ALPHABET string for the character and assign the numeric
representation of the character (plainnumeric) as the index position of the
character in the ALPHABET string.
12
ii. Perform encryption using
ciphernumeric = ( plainnumeric + Caeser cipher key ) mod 26
iii. Use ciphernumeric as the index position and get the corresponding character
from the ALPHABET string as the equivalent cipher text character for the
plain text character
b. Print the equivalent cipher text
4. Decrypt the cipher text using the Caeser cipher key and the ALPHABET string.
a. For every character in the cipher text
i. Search the ALPHABET string for the character and assign the numeric
representation of the character (ciphernumeric) as the index position of the
character in the ALPHABET string.
ii. Perform decryption using
Plainnumeric = ( ciphernumeric - Caeser cipher key ) mod 26,
if plainnumeric < 0 , plainnumeric = plainnumeric + 26
iii. Use plainnumeric as the index position and get the corresponding character
from the ALPHABET string as the equivalent plain text character for the
cipher text character
b. Print the equivalent plain text
5. Stop
PROGRAM:
import java.util.*;
import java.io.*;
13
for (int i = 0; i < ctext.length(); i++)
{
int ciphernumeric = ALPHABET.indexOf(ctext.charAt(i));
int plainnumeric= (ciphernumeric-cserkey) % 26;
if (plainnumeric < 0)
{
plainnumeric = ALPHABET.length() + plainnumeric;
}
char plainchar = ALPHABET.charAt(plainnumeric);
ptext += plainchar;
}
return ptext;
}
System.out.println("ENCRYPTION");
ciphertext = encrypt(plaintext,cserkey);
System.out.println("CIPHER TEXT :"+ ciphertext);
System.out.println("DECRYPTION");
plaintext = decrypt(ciphertext,cserkey);
System.out.println("PLAIN TEXT :" + plaintext);
}
}
14
OUTPUT:
ENCRYPTION
CIPHER TEXT :pumvythapvu
DECRYPTION
PLAIN TEXT :information
1. Crack the following plaintext TRVJRI TZGYVIJ RIV HLZKV VRJP KF TIRTB
2. What encryption key was used?
3. Make you own cipher text using the Caesar cipher.
4. Can you crack other people’s ciphertexts?
5. What key do we need to make “CAESAR” become “MKOCKB”?
6. What key do we need to make “CIPHER” become “SYFXUH”?
7. Use the Caesar cipher to encrypt your first name
8. How can we find the decryption key from the encryption key?
RESULT:
Thus the program to implement caeser cipher encryption technique was developed and
executed.
15
EX.No.:1(b) PLAY FAIR CIPHER
AIM:
To implement a program to encrypt a plain text and decrypt a cipher text using play fair
Cipher substitution technique.
PRELAB DISCUSSION:
The Playfair cipher or Playfair square is a manual symmetric encryption technique and was
the first literal digraph substitution cipher. Playfair cipher is a multi- alphabet letter encryption cipher,
which deals with letters in plaintext as single units and renders these units into Ciphertext letters. The
Playfair algorithm is based on the use of a 5X5 matrix of letters built using a keyword. The playfair
cipher starts with creating a key table. The key table is a 5×5 grid of letters that will act as the key for
encrypting your plaintext. Each of the 25 letters must be unique and one letter of the alphabet (usually
Q) is omitted or treat I and J as the same alphabet from the table (as there are 25 spots and 26 letters
in the alphabet). Let’s say we wanted to use the phrase “Hello World” as our key. The first characters
(going left to right) in the table will be the phrase, with duplicate letters removed. The rest of the table
will be filled with the remaining letters of the alphabet, in order.
The text can only contain alphabets (i.e. no spaces or punctuation). Also this cipher is case-
insensitive. We start by removing spaces from the text and duplicate letters from the key then
converting them into uppercase. If any double letters occurring in the plaintext, an 'x' is inserted
between the occurrences of the letters. In a playfair cipher the message is split into digraphs, pairs of
two letters. If there is an odd number of letters, a Z or X is added to the last letter. Now for the actual
encryption process, the Playfair cipher uses a few simple rules relating to where the letters of each
digraph are in relation to each other. Performing this quick encryption process for each digraph in the
message eventually results in the entire plaintext being encrypted. Decrypting the Playfair cipher
(assuming you have the key) is as simple as doing the same process in reverse. Assuming you have
the same key you will always be able to create the same key table, and then decrypt any messages
made using that key.
The Playfair cipher was used mainly to protect important, yet non-critical secrets, as it is
quick to use and requires no special equipment. By the time enemy cryptanalysts could break the
code the information it was protecting would often no longer be relevant.
ALGORITHM:
16
2. Remove any punctuation or characters from the plain text that are not present in the key
square.
3. Identify any double letters in the plaintext and insert ‘X’ between the two occurrences.
4. Split the plain text into digraphs (groups of 2 letters)
5. Encryption: Locate the digraph letters in the key table
a. If the letters appear on the same row of the table, replace them with the letters to
their immediate right respectively (wrapping around to the left side of the row if a
letter in the original pair was on the right side of the row).
b. If the letters appear on the same column of the table, replace them with the letters
immediately below respectively (wrapping around to the top side of the column if
a letter in the original pair was on the bottom side of the column).
c. If the letters are in different rows and columns, replace the pair with the letters on
the same row respectively but at the other pair of corners of the rectangle defined
by the original pair. The order is important – the first encrypted letter of the pair is
the one that lies on the same row as the first plaintext letter.
d. Append the letters referred from the key table using the steps 5.a, 5.b and 5.c to
generate Cipher text.
6. Decryption: Split the cipher text into digraphs and locate the digraph letters in the key table.
a. If the letters appear on the same row of the table, replace them with the letters to
their immediate left respectively (wrapping around to the right side of the row if a
letter in the original pair was on the left side of the row).
e. If the letters appear on the same column of the table, replace them with the letters
immediately above respectively (wrapping around to the bottom side of the column
if a letter in the original pair was on the top side of the column).
f. If the letters are in different rows and columns, replace the pair with the letters on
the same row respectively but at the other pair of corners of the rectangle defined
by the original pair. The order is important – the first encrypted letter of the pair is
the one that lies on the same row as the first plaintext letter.
g. Append the letters referred from the key table using the steps 6.a, 6.b and 6.c to
generate Plain text.
7. Stop
PROGRAM:
import java.util.*;
import java.io.*;
17
public void matrixgen(String key)
{
char keychar;
int count=0;
int alphacount=0;
int p,k,flg=1;
for(int i=0; i<5; i++)
{
for(int j=0;j<5;j++)
{
if (count<key.length())
{
keychar=key.charAt(count);
if (keychar == 'J')
keychar='I';
p=0;
while (p<count)
{
flg=1;
if (keychar==key.charAt(p))
{
count++;
if (count == key.length())
{
flg=0;
break;
}
keychar=key.charAt(count);
p=0;
}
else
p++;
}
if (flg!=0)
{
pfmatrix[i][j]=keychar;
count++;
}
if ((count==key.length()) && (flg==0))
{
if(alphacount<26)
{
keychar=ALPHABET.charAt(alphacount);
k=0;
while (k<key.length())
{
if ((keychar==key.charAt(k)) || (keychar=='J'))
{
alphacount++;
keychar=ALPHABET.charAt(alphacount);
k=0;
18
}
else
k++;
}
//if (keychar!='J' && k==key.length())
pfmatrix[i][j]=keychar;
alphacount++;
}
}
}
else
{
if(alphacount<26)
{
keychar=ALPHABET.charAt(alphacount);
k=0;
while (k<key.length())
{
if ((keychar==key.charAt(k)) || (keychar=='J'))
{
alphacount++;
keychar=ALPHABET.charAt(alphacount);
k=0;
}
else
k++;
}
pfmatrix[i][j]=keychar;
alphacount++;
}
}
}
}
19
String text="";
i=0;
while (i<(txt.length()-1))
{
text += txt.charAt(i);
if (txt.charAt(i) == txt.charAt(i+1))
{
text += 'X';
xpad++;
}
i++;
}
text += txt.charAt(txt.length()-1);
System.out.println("TEXT : " + text);
if (text.length()%2 != 0)
{
text += 'X';
xpad++;
}
System.out.println("FINAL TEXT : "+ text);
for(k=0;k<text.length();k=k+2)
{
ch1=text.charAt(k);
ch2=text.charAt(k+1);
System.out.println("CHARACTER PAIR :" + ch1 +" " + ch2);
matsearch(ch1);
ch1row=row;
ch1col=col;
matsearch(ch2);
ch2row=row;
ch2col=col;
// System.out.println("ch1row:" + ch1row + "ch1col:" + ch1col);
// System.out.println("ch2row:" + ch2row + "ch2col:" + ch2col);
if (ch1row==ch2row)
{
tmp1=pfmatrix[ch1row][(ch1col+1)%5];
tmp2=pfmatrix[ch2row][(ch2col+1)%5];
}
else if (ch1col==ch2col)
{
tmp1=pfmatrix[(ch1row+1)%5][ch1col];
tmp2=pfmatrix[(ch2row+1)%5][ch2col];
}
else
{
tmp1=pfmatrix[ch1row][ch2col];
tmp2=pfmatrix[ch2row][ch1col];
}
nutext += tmp1;
nutext += tmp2;
System.out.println("TRANSLATED TEXT :" + tmp1 + " " + tmp2);
}
20
return nutext;
}
21
nutext += tmp2;
System.out.println("TRANSLATED TEXT :" + tmp1 + " " + tmp2);
}
if (xpad != 0)
{
i=0;
while (i<nutext.length())
{
if (nutext.charAt(i) == 'X')
{
i++;
continue;
}
txt += nutext.charAt(i);
i++;
}
System.out.println("TEXT :" + txt);
return txt;
}
else
{
System.out.println("TEXT : " + nutext);
return nutext;
}
}
22
pfkey = sc.next();
System.out.println("PLAYFAIR MATRIX");
pf.matrixgen(pfkey);
pf.matrixdisplay();
String ptext = new String();
System.out.println("Enter PLAIN TEXT");
ptext = sc.next();
String ctext = new String();
ctext = pf.pfencryption(ptext);
System.out.println();
System.out.println("CIPHER TEXT :" + ctext);
System.out.println();
String plaintext = new String();
plaintext = pf.pfdecryption(ctext);
System.out.println();
System.out.println("PLAIN TEXT :" + plaintext);
sc.close();
}
}
OUTPUT:
C:\Program Files\Java\jdk1.8.0_71\bin>javac Playfair.java
C:\Program Files\Java\jdk1.8.0_71\bin>java Playfair
Enter the PLAYFAIR KEY:
INFORMATION
PLAYFAIR MATRIX
I N F O R
M A T B C
D E G H K
L P Q S U
V W X Y Z
Enter PLAIN TEXT
GOODMORNING
TEXT : GOXODMORNING
FINAL TEXT : GOXODMORNING
CHARACTER PAIR :G O
TRANSLATED TEXT :H F
CHARACTER PAIR :X O
TRANSLATED TEXT :Y F
CHARACTER PAIR :D M
TRANSLATED TEXT :L D
23
CHARACTER PAIR :O R
TRANSLATED TEXT :R I
CHARACTER PAIR : N I
TRANSLATED TEXT :F N
CHARACTER PAIR : N G
TRANSLATED TEXT :F E
CHARACTER PAIR :H F
TRANSLATED TEXT :G O
CHARACTER PAIR :Y F
TRANSLATED TEXT :X O
CHARACTER PAIR :L D
TRANSLATED TEXT :D M
CHARACTER PAIR :R I
TRANSLATED TEXT :O R
CHARACTER PAIR :F N
TRANSLATED TEXT :N I
CHARACTER PAIR :F E
TRANSLATED TEXT :N G
TEXT :GOODMORNING
RESULT:
Thus the program to implement Play Fair Cipher technique was developed and executed
successfully.
24
EX.No.:1(c) HILL CIPHER
AIM:
To develop a program to encrypt and decrypt using the Hill cipher substitution technique
PRELAB DISCUSSION:
The Hill cipher is a substitution cipher invented by Lester S. Hill in 1929. Hill's major
contribution was the use of mathematics to design and analyse cryptosystems. The Hill cipher is a
polygraphic substitution cipher based on linear algebra. Hill ciphers are applications of linear algebra
because a Hill cipher is simply a linear transformation represented by a matrix with respect to the
standard basis. Groups of letters are represented by vectors. The domain of the linear transformation
is all plaintext vectors, while the codomain is made up of all ciphertext vectors. Matrix multiplication
is involved in the encoding and decoding process. And when trying to find the inverse key, we will
use elementary row operations to row reduce the key matrix in order to find its inverse in the standard
manner. Each letter is represented by a number modulo 26. To encrypt a message, each block of n
letters is multiplied by an invertible n × n matrix, again modulus 26.To decrypt the message, each
block is multiplied by the inverse of the matrix used for encryption. The matrix used for encryption is
the cipher key, and it should be chosen randomly from the set of invertible n × n matrices (modulo
26).The cipher can, be adapted to an alphabet with any number of letters. All arithmetic just needs to
be done modulo the number of letters instead of modulo 26.
Encryption : Cipher text = ( Plain text * Key ) mod 26
Decryption : Plain text = ( Cipher text * Key -1 ) mod 26
ALGORITHM:
25
ii. Transpose the key matrix
iii. Find minor matrix and then Cofactor of the key matrix
iv. Key-1 = [ [ Det(key matrix) ]-1 * Cofactor ] mod 26 using modulus
arithmetic
b. Plain Text = ( Cipher Text * Key-1 ) mod 26
c. Using step 5.b, perform matrix multiplication of Cipher text matrix and Key inverse
matrix and modulus 26 to yield Plain text matrix.
d. Translate the Plain text matrix to string representation by replacing each of the entries
with the corresponding letter of the alphabet, after arranging all k of the resulting
column vectors and removing any letters padded in order into a single vector of length
kxn
6. Stop
PROGRAM:
import java.util.*;
import java.io.*;
26
{
int dtrmnt = 0;
int mulinvdtrmnt = 0;
int x, y, z, i, j, a, tmp, p, q;
int transkey[][] = new int[3][3];
int minormat[][] = new int[3][3];
int temp[][] = new int[2][2];
dtrmnt = (x-y+z)%26;
if ( dtrmnt < 0 )
dtrmnt = dtrmnt + 26;
System.out.println("DETERMINANT :" + dtrmnt);
a = dtrmnt;
for(i=0;i<25;i++)
{
tmp = ( a * i ) % 26;
if ( tmp == 1 )
{
mulinvdtrmnt = i;
break;
}
}
System.out.println("MULTIPLICATIVE INVERSE OF DETERMINANT:" +
mulinvdtrmnt);
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
transkey[i][j] = key[j][i];
}
// keydisplay(transkey);
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
p=0;
q=0;
for(x=0;x<3;x++)
{
for(y=0;y<3;y++)
{
27
if ((x!=i) && (y!=j))
{
temp[p][q] = transkey[x][y];
q++;
if ( q == 2)
{
q=0;
p++;
}
}
}
}
minormat[i][j]=(temp[0][0]*temp[1][1])-(temp[0][1]*temp[1][0]);
minormat[i][j] = minormat[i][j] * (int)Math.pow(-1,(i+j));
}
}
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
keyinverse[i][j]=(mulinvdtrmnt * minormat[i][j])%26;
if (keyinverse[i][j] < 0)
keyinverse[i][j] = keyinverse[i][j] + 26;
}
}
System.out.println("KEY INVERSE");
keydisplay(keyinverse);
}
int k, p, n;
if ((text.length() % 3) == 1)
{
n=text.length();
text += 'X';
text += 'X';
flag = 2;
}
if ((text.length() % 3) == 2)
{
text += 'X';
flag = 1;
}
row = (text.length()) / 3;
k = 0;
for(int i=0; i<row; i++)
28
{
for(int j=0;j<3;j++)
{
for (p=0;p<26;p++)
{
if (text.charAt(k) == ALPHABET.charAt(p))
{
plainmat[i][j] = p;
k++;
break;
}
}
}
}
// System.out.println("PLAIN TEXT MATRIX");
matdisplay(plainmat);
System.out.println();
}
for(i=0;i<row;i++)
{
for(j=0;j<3;j++)
{
k = mat[i][j];
txt += ALPHABET.charAt(k);
}
}
if (decrypt == 1)
{
if ( flag == 1 )
{
tmp = txt.substring(0, (txt.length()-1));
return tmp;
}
if ( flag == 2 )
{
tmp = txt.substring(0, (txt.length()-2));
return tmp;
}
}
return txt;
}
29
String ctxt="";
decrypt=0;
System.out.println("HILL CIPHER ENCRYPTION");
System.out.println("PLAIN TEXT MATRIX");
str2matrix(ptxt);
for(i=0;i<row;i++)
{
for(j=0;j<3;j++)
{
for(k=0;k<3;k++)
sum += plainmat[i][k] * key[k][j];
ciphermat[i][j] = sum % 26;
sum = 0;
}
}
decrypt=1;
System.out.println("HILL CIPHER DECRYPTION");
System.out.println("CIPHER TEXT MATRIX");
str2matrix(ctxt);
for(i=0;i<row;i++)
{
for(j=0;j<3;j++)
{
for(k=0;k<3;k++)
sum += ciphermat[i][k] * keyinverse[k][j];
plainmat[i][j] = sum % 26;
sum = 0;
}
}
System.out.println("PLAIN TEXT MATRIX");
matdisplay(plainmat);
ptxt = matrix2str(plainmat);
return ptxt;
}
30
Hillcipher hc = new Hillcipher();
Scanner sc = new Scanner(System.in);
hc.inverse();
sc.close();
}
}
OUTPUT:
C:\Program Files\Java\jdk1.8.0_71\bin>javac Hillcipher.java
C:\Program Files\Java\jdk1.8.0_71\bin>java Hillcipher
DETERMINANT : 23
KEY INVERSE
4 9 15
15 17 6
24 0 17
31
CIPHER TEXT MATRIX
17 17 11
12 22 1
10 0 18
15 3 7
DETERMINANT :23
MULTIPLICATIVE INVERSE OF DETERMINANT:17
KEY INVERSE
4 9 15
15 17 6
24 0 17
32
CIPHER TEXT MATRIX
21 9 9
4 17 2
25 9 21
1 10 0
RESULT:
Thus the program to implement Hill cipher encryption technique was developed and executed
successfully.
33
EX.No.:1(d) VIGENERE CIPHER
AIM:
PRELAB DISCUSSION:
The Vigenère Cipher was developed by mathematician Blaise de Vigenère in the 16th
century. The Vigenère Cipher was adapted as a twist on the standard Caesar cipher to reduce the
effectiveness of performing frequency analysis on the ciphertext. The cipher accomplishes this using
uses a text string (for example, a word) as a key, which is then used for doing a number of alphabet
shifts on the plaintext. Similar to the Caesar Cipher, but instead of performing a single alphabet shift
across the entire plaintext, the Vigenère cipher uses a key to determine several different shift amounts
across the entirety of the message. The Vigenère cipher uses a 26×26 table with A to Z as the row
heading and column heading This table is usually referred to as the Vigenère Tableau, Vigenère Table
or Vigenère Square. We shall use Vigenère Table. The first row of this table has the 26 English
letters. Starting with the second row, each row has the letters shifted to the left one position in a
cyclic way. For example, when B is shifted to the first position on the second row, the letter A moves
to the end.
In addition to the plaintext, the Vigenère cipher also requires a keyword, which is repeated so
that the total length is equal to that of the plaintext. In this way, each letter in the plaintext is shifted
by the alphabet number of the corresponding letter in the key. To encrypt, pick a letter in the plaintext
and its corresponding letter in the keyword, use the keyword letter and the plaintext letter as the row
index and column index, respectively, and the entry at the row-column intersection is the letter in the
ciphertext. Repeating this process until all plaintext letters are processed.
To decrypt, pick a letter in the ciphertext and its corresponding letter in the keyword, use the
keyword letter to find the corresponding row, and the letter heading of the column that contains the
ciphertext letter is the needed plaintext letter. For example, to decrypt the first letter T in the
ciphertext, we find the corresponding letter H in the keyword. Then, the row of H is used to find the
corresponding letter T and the column that contains T provides the plaintext letter M (see the above
figures). Consider the fifth letter P in the ciphertext. This letter corresponds to the keyword letter H
and row H is used to find P. Since P is on column I, the corresponding plaintext letter is I.
ALGORITHM :
1. Vigenere table consists of the alphabet written out 26 times in different rows, each alphabet
shifted cyclically to the left compared to the previous alphabet, corresponding to the 26
possible Caesar ciphers.
2. The Key is repeated so that the total length is equal to that of the plaintext. In this way, each
letter in the plaintext is shifted by the alphabet number of the corresponding letter in the key.
3. At different points in the encryption process, the cipher uses a different alphabet from one of
the rows used.
34
4. Encryption: The the plaintext(P) and key(K) are added modulo 26.
Ei = (Pi + Ki) mod 26
5. Decryption: Subtract the key from the Encrypted ( Cipher ) text and perform modulo 26 to
arrive back at the original, plaintext value
Di = (Ei - Ki + 26) mod 26
6. Stop
PROGRAM:
import java.util.*;
import java.io.*;
for(i=0;i<ptxt.length();i++)
{
nukey += keytxt.charAt(j);
j++;
if (j == keytxt.length())
j=0;
}
return nukey;
}
for(i=0;i<26;i++)
{
if ( x == ALPHABET.charAt(i))
{
35
pos = i;
break;
}
}
return pos;
}
ch = ALPHABET.charAt(y);
return ch;
}
extndkey = keyextnsn(txt,key);
System.out.println("VIGENERE ENCRYPTION");
System.out.println("PLAIN TEXT : " + txt);
System.out.println("VIGENERE KEY : " + extndkey);
for(i=0;i<txt.length();i++)
{
p = valueofchar(txt.charAt(i));
k = valueofchar(extndkey.charAt(i));
ctxt += tmp;
// System.out.println("CTXT : " + ctxt);
}
return ctxt;
}
36
String ptxt="";
System.out.println("VIGENERE DECRYPTION");
System.out.println("CIPHER TEXT : " + txt);
System.out.println("VIGENERE KEY : " + extndkey);
for(i=0;i<txt.length();i++)
{
c = valueofchar(txt.charAt(i));
k = valueofchar(extndkey.charAt(i));
tmp1 = ( c - k + 26 )%26;
ch = charofvalue(tmp1);
ptxt += ch;
}
return ptxt;
}
System.out.println("ENTER KEY");
key = sc.next();
String text = new String();
System.out.println("Enter PLAIN TEXT");
text = sc.next();
sc.close();
}
}
37
OUTPUT:
C:\Program Files\Java\jdk1.8.0_71\bin>javac Vigenerecipher.java
C:\Program Files\Java\jdk1.8.0_71\bin>java Vigenerecipher
ENTER KEY
DECEPTIVE
Enter PLAIN TEXT
WEAREDISCOVEREDSAVEYOURSELF
VIGENERE ENCRYPTION
PLAIN TEXT : WEAREDISCOVEREDSAVEYOURSELF
VIGENERE KEY : DECEPTIVEDECEPTIVEDECEPTIVE
VIGENERE DECRYPTION
CIPHER TEXT : ZICVTWQNGRZGVTWAVZHCQYGLMGJ
VIGENERE KEY : DECEPTIVEDECEPTIVEDECEPTIVE
VIGENERE DECRYPTION
CIPHER TEXT : LXFOPVEFRNHR
VIGENERE KEY : LEMONLEMONLE
C:\Program Files\Java\jdk1.8.0_71\bin>
38
VIVA QUESTIONS (PRELAB and POSTLAB):
RESULT:
Thus the program to implement Vigenere cipher encryption technique was developed and
executed successfully.
39
EX.No.: 2 RAIL FENCE CIPHER
AIM:
To develop a program for implementing encryption and decryption using rail fence
transposition technique.
PRELAB DISCUSSION:
The rail fence is the simplest example of a class of transposition ciphers, known as
route ciphers. In general, the elements of the plaintext (usually single letters) are written in a
prearranged order (route) into a geometric array (matrix)—typically a rectangle—agreed upon in
advance by the transmitter and receiver and then read off by following another prescribed route
through the matrix to produce the cipher. The key in a route cipher consists of keeping secret the
geometric array, the starting point, and the routes. Clearly both the matrix and the routes can be
much more complex than in this example; but even so, they provide little security. One form of
transposition (permutation) that was widely used depends on an easily remembered key word for
identifying the route in which the columns of a rectangular matrix are to be read. For example,
using the key word AUTHOR and ordering the columns by the lexicographic order of the letters
in the key word.
In decrypting a route cipher, the receiver enters the cipher text symbols into the agreed-upon
matrix according to the encryption route and then reads the plaintext according to the original
order of entry. A significant improvement in crypto security can be achieved by reencrypting the
cipher obtained from one transposition with another transposition. Because the result
(product) of two transpositions is also a transposition, the effect of multiple transpositions is to
define a complex route in the matrix, which in itself would be difficult to describe by any simple
mnemonic.
ALGORITHM DESCRIPTION:
In the rail fence cipher, the plaintext is written downwards and diagonally on successive "rails" of
an imaginary fence, then moving up when we reach the bottom rail. When we reach the top rail, the
message is written downwards again until the whole plaintext is written out. The message is then
read off in rows.
1. Generate numerical key from the word key by the characters of the word in alphabetical
order.
2. Encryption
i. The plain text is written in the matrix form, where the column of the matrix is
number of characters in the word key and row of the matrix is to accommodate
the characters of the plain text and the space left after the plain text characters
in the last row is filled with any character. (eg. x or z)
ii. The cipher text is generated by reading the characters column by column in the order
specified in the numerical key.
40
3. Decryption
i. The characters in the cipher text are filled in the matrix of same order used for
encryption, but in the order specified in the key. The characters from cipher text equal
to the number of rows in matrix are taken and filled in the matrix column based on the
order specified in the key
ii. The plain text is generated from cipher text by reading the characters from the matrix
row by row.
4. Stop
PROGRAM:
import java.util.*;
import java.io.*;
for(i=0;i<len;i++)
text += text1.charAt(i);
if (( len % 7 ) != 0)
{
rows = ( len / 7 ) + 1;
ch = len % 7;
for (i=0;i<(7-ch);i++)
text += 'X';
}
else
rows = len / 7;
k=0;
for(i=1;i<=rows;i++)
{
41
for(j=1;j<=7;j++)
mat[i][j] = text.charAt(k++);
}
for(i=1;i<=rows;i++)
{
for(j=1;j<=7;j++)
System.out.print(mat[i][j] + " ");
System.out.println();
}
k = 1;
j = 1;
while ( k <= 7 )
{
for(p=0;p<7;p++)
{
if ( k == key[p] )
{
j=p+1;
k++;
break;
}
}
for(i=1;i<=rows;i++)
enctxt+=mat[i][j];
}
System.out.println(enctxt);
return enctxt;
}
while (k<=7)
{
for(p=0;p<7;p++)
{
if (key[p] == k)
{
j = p+1;
k++;
42
break;
}
}
for(i=1;i<=rows;i++)
cmat[i][j] = txt.charAt(q++);
}
for(i=1;i<=rows;i++)
{
for(j=1;j<=7;j++)
System.out.print(cmat[i][j] + " ");
System.out.println();
}
for(i=1;i<=rows;i++)
{
for(j=1;j<=7;j++)
dectxt += cmat[i][j];
}
len = dectxt.length();
if (plength < len)
{
for(i=0;i<plength;i++)
ptext += dectxt.charAt(i);
}
return ptext;
}
System.out.println("Enter key");
for(i=0;i<7;i++)
{
c = br.readLine();
key[i] = Integer.parseInt(c);
}
43
for(i=0;i<7;i++)
System.out.print(key[i] + " ");
System.out.println(plain);
String ctext = new String();
ctext = rf.rfencryption(plain);
System.out.println();
System.out.println("CIPHER TEXT :" + ctext);
System.out.println();
sc.close();
}
}
OUTPUT:
ATT AC K
POSTPO
NEDUNT
ILTWOA
MXXXXX
APNIMKOTAXCPNOXTOELXTSDTXATUWX
44
CIPHER TEXT :APNIMKOTAXCPNOXTOELXTSDTXATUWX
ATT AC K
POSTPO
NEDUNT
ILTWOA
MXXXXX
C:\Program Files\Java\jdk1.8.0_71\bin>
RESULT:
Thus the program for Railfence cipher was executed and verified successfully.
45
EX.No.: 3 DATA ENCRYPTION STANDARD (DES)
AIM:
To develop a program to implement Data Encryption Standard for encryption and decryption.
PRELAB DISCUSSION:
The Data Encryption Standard (DES) is a symmetric-key block cipher published by the
National Institute of Standards and Technology (NIST).
DES is an implementation of a Feistel Cipher. It uses 16 round Feistel structure. The block
size is 64-bit.
Though, key length is 64-bit, DES has an effective key length of 56 bits, since 8 of the 64 bits
of the key are not used by the encryption algorithm (function as check bits only).
General Structure of DES is depicted in the following illustration
ALGORITHM:
1. Process the key.
i. Get a 64-bit key from the user.
ii. Calculate the key schedule.
1. Perform the following permutation on the 64-bit key. The parity bits are
discarded, reducing the key to 56 bits. Bit 1 of the permuted block is bit 57 of
the original key, bit 2 is bit 49, and so on with bit 56 being bit 4 of the
original key.
2. Split the permuted key into two halves. The first 28 bits are called C[0] and
the last 28 bits are called D[0].
46
3. Calculate the 16 subkeys. Start with i = 1.
1. Perform one or two circular left shifts on both C[i-1] and D[i-1] to
get C[i] and D[i], respectively. The number of shifts per iteration are
given in the table below.
Iteration # 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
Left Shifts 1 1 2 2 2 2 2 2 1 2 2 2 2 2 2 1
2. Permute the concatenation C[i]D[i] as indicated below. This will
yield K[i], which is 48 bits long.
3. Loop back to 1.ii.c.1 until K[16] has been calculated.
2 Process a 64-bit data block.
i. Get a 64-bit data block. If the block is shorter than 64 bits, it should be padded
as appropriate for the application.
ii. Perform the initial permutation on the data block.
iii. Split the block into two halves. The first 32 bits are called L[0], and the last 32 bits
are called R[0].
iv. Apply the 16 subkeys to the data block. Start with i = 1.
a. Expand the 32-bit R[i-1] into 48 bits according to the bit-selection
function Expansion (E)
b. Exclusive-or E(R[i-1]) with K[i].
c. Break E(R[i-1]) xor K[i] into eight 6-bit blocks. Bits 1-6 are B[1], bits 7-12
are B[2], and so on with bits 43-48 being B[8].
d. Substitute the values found in the S-boxes for all B[j]. Start with j = 1. All
values in the S-boxes should be considered 4 bits wide.
i. Take the 1st and 6th bits of B[j] together as a 2-bit value (call it m)
indicating the row in S[j] to look in for the substitution.
ii. Take the 2nd through 5th bits of B[j] together as a 4-bit value(call it n)
indicating the column in S[j] to find the substitution.
iii. Replace B[j] with S[j][m][n].
iv. Loop back to 2.iv.d.i until all 8 blocks have been replaced.
e. Permute the concatenation of B[1] through B[8]
f. Exclusive-or the resulting value with L[i-1]. Thus, all together, your
R[i] = L[i-1] xor P(S[1](B[1])...S[8](B[8])), where B[j] is a 6-bit block of E(R[i-1])
xor K[i]. (The function for R[i] is written as, R[i] = L[i-1] xor f(R[i-1], K[i]).)
g. L[i] = R[i-1].
h. Loop back to 2.iv.a until K[16] has been applied.
v. Perform the final permutation on the block R[16]L[16].
3.Decryption : Use the keys K[i] in reverse order. That is, instead of applying K[1] for the first
iteration, apply K[16], and then K[15] for the second, on down to K[1]
PROGRAM:
DES :-
import javax.swing.*;
import java.security.SecureRandom;
47
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Random ;
class DES {
byte[] skey = new byte[1000];
String skeyString;
static byte[] raw;
String inputMessage,encryptedData,decryptedMessage;
public DES() {
try {
generateSymmetricKey();
inputMessage=JOptionPane.showInputDialog(null,"Enter message to encrypt");
byte[] ibyte = inputMessage.getBytes();
byte[] ebyte=encrypt(raw, ibyte);
String encryptedData = new String(ebyte);
System.out.println("Encrypted message "+encryptedData);
JOptionPane.showMessageDialog(null,"Encrypted Data "+"\n"+encryptedData);
byte[] dbyte= decrypt(raw,ebyte);
String decryptedMessage = new String(dbyte);
System.out.println("Decrypted message "+decryptedMessage);
JOptionPane.showMessageDialog(null,"Decrypted Data "+"\n"+decryptedMessage);
}
catch(Exception e) {
System.out.println(e);
}
}
void generateSymmetricKey() {
try {
Random r = new Random();
intnum = r.nextInt(10000);
String knum = String.valueOf(num);
byte[] knumb = knum.getBytes();
skey=getRawKey(knumb);
skeyString = new String(skey);
System.out.println("DES Symmetric key = "+skeyString);
}
catch(Exception e) {
System.out.println(e);
}
}
private static byte[] getRawKey(byte[] seed) throws Exception {
KeyGeneratorkgen = KeyGenerator.getInstance("DES");
SecureRandomsr = SecureRandom.getInstance("SHA1PRNG");
sr.setSeed(seed);
48
kgen.init(56, sr);
SecretKeyskey = kgen.generateKey();
raw = skey.getEncoded();
return raw;
}
private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {
SecretKeySpecskeySpec = new SecretKeySpec(raw, "DES");
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] encrypted = cipher.doFinal(clear);
return encrypted;
}
private static byte[] decrypt(byte[] raw, byte[] encrypted) throws Exception {
SecretKeySpecskeySpec = new SecretKeySpec(raw, "DES");
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE, skeySpec);
byte[] decrypted = cipher.doFinal(encrypted);
return decrypted;
}
public static void main(String args[]) {
DES des = new DES();
}
}
OUTPUT:
49
VIVA QUESTIONS (PRELAB and POSTLAB):
RESULT:
Thus the program to implement DES encryption technique was developed and executed
successfully
50
EX.No.: 4 AES ALGORITHM
AIM:
To develop a program to implement Advanced Encryption Standard for encryption and
decryption.
PRELAB DISCUSSION:
The cipher takes a plaintext block size of 128 bits, or 16 bytes. The key length can be 16, 24,
or 32 bytes (128, 192, or 256 bits). The algorithm is referred to as AES-128, AES-192, or AES-256,
depending on the key length.
The input to the encryption and decryption algorithms is a single 128-bit block. In FIPS PUB
197, this block is depicted as a 4 * 4 square matrix of bytes. This block is copied into the State array,
which is modified at each stage of encryption or decryption. After the final stage, State is copied to
an output matrix. Similarly, the key is depicted as a square matrix of bytes. This key is then expanded
51
into an array of key schedule words. Each word is four bytes, and the total key schedule is 44 words
for the 128-bit key. Note that the ordering of bytes within a matrix is by column. So, for example, the
first four bytes of a 128-bit plaintext input to the encryption cipher occupy the first column of the in
matrix, the second four bytes occupy the second column, and so on. Similarly, the first four bytes of
the expanded key, which form a word, occupy the first column of the w matrix.
The cipher consists of N rounds, where the number of rounds depends on the key length: 10
rounds for a 16-byte key, 12 rounds for a 24-byte key, and 14 rounds for a 32-byte key. The first N - 1
rounds consist of four distinct transformation functions: SubBytes, ShiftRows, MixColumns, and
AddRoundKey. The final round contains only three transformations, and there is a initial single
transformation (AddRoundKey) before the first round, which can be considered Round 0. Each
transformation takes one or more 4 * 4 matrices
PROGRAM:
package com.includehelp.stringsample;
import java.util.Base64;
import java.util.Scanner;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
/**
* Program to Encrypt/Decrypt String Using AES 128 bit Encryption Algorithm
*/
public class EncryptDecryptString
{
private static final String encryptionKey = "ABCDEFGHIJKLMNOP";
private static final String characterEncoding = "UTF-8";
private static final String cipherTransformation = "AES/CBC/PKCS5PADDING";
private static final String aesEncryptionAlgorithem = "AES";
/**
* Method for Encrypt Plain String Data
* @param plainText
* @return encryptedText
*/
public static String encrypt(String plainText)
{
String encryptedText = "";
try
{
Cipher cipher = Cipher.getInstance(cipherTransformation);
byte[] key = encryptionKey.getBytes(characterEncoding);
SecretKeySpec secretKey = new SecretKeySpec(key, aesEncryptionAlgorithem);
IvParameterSpec ivparameterspec = new IvParameterSpec(key);
cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivparameterspec);
byte[] cipherText = cipher.doFinal(plainText.getBytes("UTF8"));
52
Base64.Encoder encoder = Base64.getEncoder();
encryptedText = encoder.encodeToString(cipherText);
} catch (Exception E)
{
System.err.println("Encrypt Exception : "+E.getMessage());
}
return encryptedText;
}
/**
* Method For Get encryptedText and Decrypted provided String
* @param encryptedText
* @return decryptedText
*/
public static String decrypt(String encryptedText)
{
String decryptedText = "";
try
{
Cipher cipher = Cipher.getInstance(cipherTransformation);
byte[] key = encryptionKey.getBytes(characterEncoding);
SecretKeySpec secretKey = new SecretKeySpec(key, aesEncryptionAlgorithem);
IvParameterSpec ivparameterspec = new IvParameterSpec(key);
cipher.init(Cipher.DECRYPT_MODE, secretKey, ivparameterspec);
Base64.Decoder decoder = Base64.getDecoder();
byte[] cipherText = decoder.decode(encryptedText.getBytes("UTF8"));
decryptedText = new String(cipher.doFinal(cipherText), "UTF-8");
} catch (Exception E)
{
System.err.println("decrypt Exception : "+E.getMessage());
}
return decryptedText;
}
53
OUTPUT:
RESULT:
Thus the program to implement AES encryption technique was developed and
executed successfully.
54
EX.No.: 5 RSA ALGORITHM
AIM:
Develop a program to implement RSA algorithm for encryption and decryption. This
cryptosystem is one the initial system. It remains most employed cryptosystem even today. The
system was invented by three scholars Ron Rivest, Adi Shamir, and Len Adleman and hence, it is
termed as RSA cryptosystem. The two aspects of the RSA cryptosystem, firstly generation of key pair
and secondly encryption-decryption algorithms
PRELAB DISCUSSION:
Generation of RSA Key Pair
Each person or a party who desires to participate in communication using encryption needs to
generate a pair of keys, namely public key and private key.
The process followed in the generation of keys is described below −
Generate the RSA modulus (n)
Select two large primes, p and q.
Calculate n=p*q. For strong unbreakable encryption, let n be a large number, typically
a minimum of 512 bits.
Find Derived Number (e)
Number e must be greater than 1 and less than (p − 1)(q − 1).
There must be no common factor for e and (p − 1)(q − 1) except for 1. In other words
two numbers e and (p – 1)(q – 1) are coprime.
Form the public key
The pair of numbers (n, e) form the RSA public key and is made public.
Interestingly, though n is part of the public key, difficulty in factorizing a large prime
number ensures that attacker cannot find in finite time the two primes (p & q) used to
obtain n. This is strength of RSA.
Generate the private key
Private Key d is calculated from p, q, and e. For given n and e, there is unique number
d.
Number d is the inverse of e modulo (p - 1)(q – 1). This means that d is the number
less than (p - 1)(q - 1) such that when multiplied by e, it is equal to 1 modulo (p - 1)(q
- 1).
This relationship is written mathematically as follows ed = 1 mod (p − 1)(q − 1)
The Extended Euclidean Algorithm takes p, q, and e as input and gives d as output.
ALGORITHM:
1. Key Generation
i. Choose two distinct prime numbers p and q.
ii. Find n such that n = pq, n will be used as the modulus for both the public
and private keys.
iii. Find the totient of n, ϕ(n) ϕ(n)=(p-1)(q-1)
iv. Choose an e such that 1 < e < ϕ(n), and such that e and ϕ(n) share no
divisors other than 1 (e and ϕ(n) are relatively prime). e is kept as the public
55
key exponent
v. Determine d (using modular arithmetic) which satisfies the congruence
relation
de ≡ 1 (mod ϕ(n)).
The public key has modulus n and the public (or encryption) exponent
e. The private key has modulus n and the private (or decryption) exponent d,
which is kept secret.
2. Encryption
c ≡ me (mod n).
3. Decryption:
m ≡ cd (mod n).
4. Stop.
PROGRAM:
import java.math.BigInteger;
import java.util.Random;
import java.io.*;
class rsaAlg
{
private BigInteger p, q, n, phi, e, d; /* public key components */
private int bitLen = 1024;
private int blkSz = 256; /* block size in bytes */
private Random rand;
/* convert bytes to string */
private static String bytesToString(byte[] encrypted)
{
String str = "";
for (byte b : encrypted)
{
str += Byte.toString(b);
}
return str;
}
/* encrypt message */
public byte[] encrypt(byte[] msg)
{
return (new BigInteger(msg)).modPow(e, n).toByteArray();
}
/* decrypt message */
public byte[] decrypt(byte[] msg)
{
return (new BigInteger(msg)).modPow(d, n).toByteArray();
}
/* calculate public key components p, q, n, phi, e, d */
public rsaAlg()
{
56
rand = new Random();
p = BigInteger.probablePrime(bitLen, rand);
q = BigInteger.probablePrime(bitLen, rand);
n = p.multiply(q);
phi = p.subtract(BigInteger.ONE).multiply(q.subtract(BigInteger.ONE));
e = BigInteger.probablePrime(bitLen/2, rand);
while (phi.gcd(e).compareTo(BigInteger.ONE) > 0 &&
e.compareTo(phi) < 0)
{
e.add(BigInteger.ONE);
}
d = e.modInverse(phi);
}
public rsaAlg (BigInteger e, BigInteger d, BigInteger n)
{
this.e = e;
this.d = d;
this.n = n;
}
public static void main (String[] args) throws java.lang.Exception
{
rsaAlg rsaObj = new rsaAlg();
String msg = "Hello world! Security Laboratory";
System.out.println("simulation of RSA algorithm");
System.out.println("message(string) : " + msg);
System.out.println("message(bytes) : " +
bytesToString(msg.getBytes()));
/* encrypt test message */
byte[] ciphertext = rsaObj.encrypt(msg.getBytes());
System.out.println("ciphertext(bytes) : " + bytesToString(ciphertext));
/* decrypt ciphertext */
byte[] plaintext = rsaObj.decrypt(ciphertext);
System.out.println("plaintext(bytes) : " + bytesToString(plaintext));
System.out.println("plaintext(string) : " + new String(plaintext)); } }
57
Output:
RESULT:
Thus the program for implementation of RSA algorithm was executed and verified
successfully.
58
EX.No.: 6 DIFFIEE HELLMAN KEY EXCHANGE ALGORITHM
AIM:
Develop a program to implement Diffie Hellman Key Exchange Algorithm for encryption and
Decryption.
PRELAB DISCUSSION:
59
ALGORITHM
PROGRAM:
import java.io.*;
import java.math.BigInteger;
class Diffie
{
public static void main(String[]args)throws IOException
{
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
System.out.println("Enter prime number:");
BigInteger p=new BigInteger(br.readLine());
System.out.print("Enter primitive root of "+p+":");
BigInteger g=new BigInteger(br.readLine());
System.out.println("Enter value for x less than "+p+":");
BigInteger x=new BigInteger(br.readLine());
BigInteger R1=g.modPow(x,p);
System.out.println("R1="+R1);
System.out.print("Enter value for y less than "+p+":");
BigInteger y=new BigInteger(br.readLine());
BigInteger R2=g.modPow(y,p);
System.out.println("R2="+R2);
BigInteger k1=R2.modPow(x,p);
System.out.println("Key calculated at Sender's side:"+k1);
BigInteger k2=R1.modPow(y,p);
System.out.println("Key calculated at Receiver's side:"+k2);
System.out.println("deffie hellman secret key Encryption has Taken");
}
}
60
OUTPUT:
RESULT:
Thus the program to implement Diffie-Hellman Key Exchange algorithm was developed and
executed successfully
61
EX.No.: 7 IMPLEMENT SECURE HASH FUNCTION (SHA)
AIM:
PRELAB DISCUSSION:
In cryptography, SHA-1 (Secure Hash Algorithm 1) is a cryptographic
hash function which takes an input and produces a 160-bit (20-byte) hash value known as a message
digest - typically rendered as a hexadecimal number, 40 digits long.
Secure Hashing Algorithms, also known as SHA, are a family of cryptographic
functions designed to keep data secured. It works by transforming the data using a hash function:
an algorithm that consists of bitwise operations, modular additions, and compression functions.
The hash function then produces a fixed size string that looks nothing like the original. These
algorithms are designed to be one-way functions, meaning that once they’re transformed into
their respective hash values, it’s virtually impossible to transform them back into the original data.
A few algorithms of interest are SHA-1, SHA-2, and SHA-5, each of which was successively
designed with increasingly stronger encryption in response to hacker attacks. SHA-0, for instance,
is now obsolete due to the widely exposed vulnerabilities.
A common application of SHA is to encrypting passwords, as the server side only needs to
keep track of specific user’s hash value, rather than the actual password. This is helpful in case an
attacker hacks the database, as they will only find the hashed functions and not the actual
passwords, so if they were to input the hashed value as a password, the hash function will convert it
into another string and subsequently deny access. Additionally, SHA exhibit the avalanche effect,
where the modification of very few letters being encrypted cause a big change in output; or
conversely, drastically different strings produce similar hash values. This effect causes hash
values to not give any information regarding the input string, such as its original length. In
addition, SHAs are also used to detect the tampering of data by attackers, where if a text file is
slightly changed and barely noticeable, the modified file’s hash value will be different than the
original file’s hash value, and the tampering will be rather noticeable.
ALGORITHM:
1. Append Padding Bits: Message is “padded” with a 1 and as many 0’s as necessary to bring
the message length to 64 bits less than an even multiple of 512.
2. Append Length: 64 bits are appended to the end of the padded message. These bits hold
the binary format of 64 bits indicating the length of the original message.
3. Prepare Processing Functions: SHA1 requires 80 processing functions defined as:
f(t;B,C,D) = (B AND C) OR ((NOT B) AND D) ( 0 <= t <= 19)
f(t;B,C,D) = B XOR C XOR D (20 <= t <= 39)
f(t;B,C,D) = (B AND C) OR (B AND D) OR (C AND D) (40 <= t<=59)
f(t;B,C,D) = B XOR C XOR D (60 <= t <= 79)
62
4. Prepare Processing Constants: SHA1 requires 80 processing constant words defined as:
K(t) = 0x5A827999 ( 0 <= t <= 19)
K(t) = 0x6ED9EBA1 (20 <= t <= 39)
K(t) = 0x8F1BBCDC (40 <= t <= 59)
K(t) = 0xCA62C1D6 (60 <= t <= 79)
5. Initialize Buffers: SHA1 requires 160 bits or 5 buffers of words (32 bits):
H0 = 0x67452301 H1 = 0xEFCDAB89
H2 = 0x98BADCFE H3 = 0x10325476
H4 = 0xC3D2E1F0
6. Processing Message in 512-bit blocks (L blocks in total message)
i. This is the main task of SHA1 algorithm which loops through the
padded and appended message in 512-bit blocks.
ii. Input and predefined functions: M[1, 2, ..., L]: Blocks of the padded
and appended message f(0;B,C,D), f(1,B,C,D), ..., f(79,B,C,D): 80
Processing Functions
K(0), K(1), ..., K(79): 80 Processing Constant Words
H0, H1, H2, H3, H4, H5: 5 Word buffers with initial values
7. For loop on k = 1 to L
1. (W(0),W(1),...,W(15)) = M[k] /* Divide M[k] into 16 words */
8. For t = 16 to 79 do:
W(t) = (W(t-3) XOR W(t-8) XOR W(t-14) XOR W(t-16)) <<< 1
A = H0, B = H1, C = H2, D = H3, E = H4
For t = 0 to 79 do:
TEMP = A<<<5 + f(t;B,C,D) + E + W(t) + K(t)
E = D, D = C, C = B<<<30, B = A, A = TEMP
End of for loop
H0 = H0 + A, H1 = H1 + B, H2 = H2 + C, H3 = H3 + D, H4 = H4 + E
End of for loop
PROGRAM
import java.security.*;
public class SHA1 {
public static void main(String[] a) {
try {
MessageDigest md = MessageDigest.getInstance("SHA1");
String input = "srm";
md.update(input.getBytes());
byte[] output = md.digest();
System.out.println();
System.out.println("SHA1(\""+input+"\") = " +bytesToHex(output));
input = "vec";
md.update(input.getBytes());
output = md.digest();
63
System.out.println();
System.out.println("SHA1(\""+input+"\") = " +bytesToHex(output));
input = "valliammai";
md.update(input.getBytes());
output = md.digest();
System.out.println();
System.out.println("SHA1(\"" +input+"\") = " +bytesToHex(output));
System.out.println(""); }
catch (Exception e) {
System.out.println("Exception: " +e);
}
}
public static String bytesToHex(byte[] b) {
char hexDigit[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
StringBuffer buf = new StringBuffer();
for (int j=0; j<b.length; j++) {
buf.append(hexDigit[(b[j] >> 4) & 0x0f]);
buf.append(hexDigit[b[j] & 0x0f]); }
return buf.toString(); }
}
OUTPUT:
64
VIVA QUESTIONS (PRELAB and POSTLAB):
RESULT:
Thus the program to implement Secure Hash Algorithm was developed and executed
successfully.
65
EX.No.: 8 IMPLEMENT DIGITAL SIGNATURE SCHEME
AIM:
To write a program to implement the digital signature scheme in java
PRELAB DISCUSSION:
Digital signatures are based on public key cryptography, also known as
asymmetric cryptography. Using a public key algorithm such as RSA, one can generate two
keys that are mathematically linked: one private and one public. To create a digital signature,
signing software (such as an email program) creates a one-way hash of the electronic data to be
signed. The private key is then used to encrypt the hash. The encrypted hash -- along with other
information, such as the hashing algorithm -- is the digital signature. The reason for encrypting
the hash instead of the entire message or document is that a hash function can convert an arbitrary
input into a fixed length value, which is usually much shorter. This saves time since hashing is
much faster than signing. The value of the hash is unique to the hashed data. Any change in the
data, even changing or deleting a single character, results in a different value. This attribute
enables others to validate the integrity of the data by using the signer's public key to decrypt the
hash. If the decrypted hash matches a second computed hash of the same data, it proves that the
data hasn't changed since it was signed. If the two hashes don't match, the data has either been
tampered with in some way (integrity) or the signature was created with a private key that doesn't
correspond to the public key presented by the signer (authentication).
A digital signature can be used with any kind of message -- whether it is encrypted or not --
simply so the receiver can be sure of the sender's identity and that the message arrived intact.
Digital signatures make it difficult for the signer to deny having signed something (non-repudiation)
-- assuming their private key has not been compromised -- as the digital signature is unique to both
the document and the signer, and it binds them together. A digital certificate, an electronic
document that contains the digital signature of the certificate-issuing authority, binds together a
public key with an identity and can be used to verify a public key belongs to a particular person or
entity. Most modern email programs support the use of digital signatures and digital certificates,
making it easy to sign any outgoing emails and validate digitally signed incoming messages. Digital
signatures are also used extensively to provide proof of authenticity, data integrity and non-
repudiation of communications and transactions conducted over the Internet.
ALGORITHM:
1. Choose a prime number q, which is called the prime divisor.
2. Choose another primer number p, such that p-1 mod q = 0. p is called the prime modulus.
3. Choose an integer g, such that 1 < g < p, g**q mod p = 1 and g = h**((p–1)/q) mod p. q
is also called g's multiplicative order modulo p.
4. Choose an integer, such that 0 < x < q.
5. Compute y as g**x mod p.
6. Package the public key as {p,q,g,y}, {p,q,g,x}.
66
7. Generate the message digest h, using a hash algorithm like SHA1.
8. Generate a random number k, such that 0 < k < q.
9. Compute r as (g**k mod p) mod q. If r = 0, select a different k.
10. Compute i, such that k*i mod q = 1. i is called the modular multiplicative inverse of
k modulo q.
11. Compute s = i*(h+r*x) mod q. If s = 0, select a different k.
12. Package the digital signature as {r,s}.
13. Generate the message digest h, using the same hash algorithm.
14. Compute w, such that s*w mod q = 1. w is called the modular multiplicative inverse
of s modulo q.
15. Compute u1 = h*w mod q. Compute u2 = r*w mod q.
16. Compute v = (((g**u1)*(y**u2)) mod p) mod q.
17. If v == r, the digital signature is valid.
PROGRAM
import java.util.*;
import java.math.BigInteger;
class dsaAlg
{
final static BigInteger one = new BigInteger("1");
final static BigInteger zero = new BigInteger("0");
67
n = n.divide(start);
}
return n;
}
68
/* secret information */
System.out.println("secret information are:");
System.out.println("x (private) is: " + x);
System.out.println("k (secret) is: " + k);
System.out.println("y (public) is: " + y);
System.out.println("h (rndhash) is: " + hashVal);
System.out.println("Generating digital signature:");
System.out.println("r is : " + r);
System.out.println("s is : " + s);
69
OUTPUT
RESULT:
Thus the program to implement Digital Signature was developed and executed successfully
70
DEMONSTRATE INTRUSION DETECTION SYSTEM (IDs) USING
EX.No.: 9
ANY TOOL (SNORT OR ANY OTHER S/W)
AIM:
Steps to configure Snort on Widnows machine and how to use it for detection of attacks.
2. Steps:
1. Download Snort from "http://www.snort.org/" website.
2. Also download Rules from the same website. You need to sign up to get rules for registered users.
3. Click on the Snort_(version-number)_Installer.exe file to install it. By-default it will install snort in
the "C:\Snort" directory.
4. Extract downloaded Rules file: snortrules-snapshot-(number).tar.gz
5. Copy all files from the "rules" directory of the extracted folder and paste them into "C:\Snort\rules"
directory.
6. Copy "snort.conf" file from the "etc" directory of the extracted folder and paste it into
"C:\Snort\etc" directory. Overwrite existing file if there is any.
7. Open command prompt (cmd.exe) and navigate to directory "C:\Snort\bin" directory.
8. To execute snort in sniffer mode use following command:
snort -dev -i 2
-i indicate interface number.
-dev is used to run snort to capture packets.
To check interface list use following command: snort -W
9. To execute snort in IDS mode, we need to configure a file "snort.conf" according to our network
environment.
10. Set up network address we want to protect in snort.conf file. To do that look for "HOME_NET"
and add your IP address.
var HOME_NET 10.1.1.17/8
11. You can also set addresses or DNS_SERVERS, if you have any. otherwise go to the next step.
12. Change RULE_PATH variable with the path of rules directory.
var RULE_PATH c:\snort\rules
13. Change the path of all libraries with the name and path on your system. or change path
of snort_dynamicpreprocessorvariable.
71
sor file C:\Snort\lib\snort_dynamiccpreprocessor\sf_dcerpc.dll
You need to do this to all library files in the "C:\Snort\lib" directory. The old path might be
something like: "/usr/local/lib/...". you need to replace that path with you system path.
14. Change path of the "dynamicengine" variable value in the "snort.conf" file with the path of your
system. Such as:
dynamicengine C:\Snort\lib\snort_dynamicengine\sf_engine.dll
15 Add complete path for "include classification.config" and "include reference.config" files.
include c:\snort\etc\classification.config
include c:\snort\etc\reference.config
16. Remove the comment on the line to allow ICMP rules, if it is alredy commented.
include $RULE_PATH/icmp.rules
17. Similary, remove the comment of ICMP-info rules comment, if it is already commented.
include $RULE_PATH/icmp-info.rules
18 To add log file to store alerts generated by snort, search for "output log" test and add following
line:
output alert_fast: snort-alerts.ids
19. Comment whitelist $WHITE_LIST_PATH/white_list.rules and blacklist
$BLACK_LIST_PATH/black_list.rules lines. Also ensure that you add change the line above
$WHITE_LIST_PATH
Change nested_ip inner , \ to nested_ip inner #, \
20. Comment following lines:
#preprocessor normalize_ip4
#preprocessor normalize_tcp: ips ecn stream
#preprocessor normalize_icmp4
#preprocessor normalize_ip6
#preprocessor normalize_icmp6
21. Save the "snort.conf" file and close it.
22. Go to the "C:\Snort\log" directory and create a file: snort-alerts.ids
23. To start snort in IDS mode, run following command:
snort -c c:\snort\etc\snort.conf -l c:\snort\log -i 2
Above command will generate log file that will not be readable without using a tool. To read it use
following command:
C:\Snort\Bin\> snort -r ..\log\log-filename
To generate Log files in ASCII mode use following command while running snort in IDS mode:
snort -A console -i2 -c c:\Snort\etc\snort.conf -l c:\Snort\log -K ascii
72
24. Scan the computer running snort from another computer using PING or launch attack. Then
check snort-alerts.ids file the log folder.
RESULT:
Thus the intrusion detection system (ids) using the tool snort program was demonstrated
and verified successfully.
73
AUTOMATED ATTACK AND PENETRATION TOOLS EXPLORING
EX.No.: 10
N-STALKER, A VULNERABILITY ASSESSMENT TOOL
AIM:
To explore automated and penetration tools on network (KF Sensor)
PRELAB DISCUSSION:
HONEYPOTS
When it comes to computer security, honeypots are all the rage. Honeypots can detect
unauthorized activities that might never be picked up by a traditional intrusion detection system.
Furthermore, since almost all access to a honeypot is unauthorized, nearly everything in a honeypot's
logs is worth paying attention to. Honeypots can act as a decoy to keep hackers away from your
production servers. At the same time though, a honeypot can be a little tricky to deploy. In this
article, I will walk you through the process of deploying a honeypot.
INTRODUCTION
There are many different types of honeypot systems. Honeypots can be hardware appliances
or they can be software based. Software based firewalls can reside on top of a variety of operating
systems. For the most part though, honeypots fall into two basic categories; real and virtual.
A virtual honeypot is essentially an emulated server. There are both hardware and software
implementations of virtual honeypots. For example, if a network administrator was concerned that
someone might try to exploit an FTP server, the administrator might deploy a honeypot appliance
that emulates an FTP server.
Using KFSensor
Step1: You will see the main KFSensor screen shown
74
As you can see, the column on the left contains a list of port numbers and what the port is typically
used for.
If the icon to the left of a port listing is green, it means that KFSensor is actively monitoring that
port for attacks.
If the icon is blue, it means that there has been an error and KFSensor is not watching for exploits
aimed at that particular port.
Once you've got the software up and running, one of the best things that you can do is to test the
software by launching a port scan against the machine that's running KFSensor.
For the port scan, we using the HostScan.
It simply scans a block of IP addresses, looking for open ports. Figure B shows how the KFSensor
reacts to a partial port scan.
If you look at Figure B, you will notice that the icons next to ports that were scanned turn red to
indicate recent activity.
75
Modifying the Honeypot's behavior
To create or modify rules, select the Edit Active Scenario command from the scenario menu.
When you do, you will see a dialog box which contains a summary of all of the existing rules.
You can either select a rule and click the Edit button to edit a rule, or you can click the Add
button to create a new rule.
Both procedures work similarly.
Click the Add button and you will see the Add Listen dialog box, shown in Figure D.
The first thing that this dialog box asks for is a name. This is just a name for the rule.
Pick something descriptive though, because the name that you enter is what will show up
in the logs whenever the rule is triggered.
76
Click on Add Button
The next few fields are protocol, port, and Bind Address. These fields allow you to choose
what the rule is listening for. For example, you could configure the rule to listen to TCP port
1023 on IP address 192.168.1.100. The bind address portion of the rule is optional though. If
you leave the bind address blank, the rule will listen across all of the machine's NICs.
Now that you have defined the listener, it's time to configure the action that the rule takes
when traffic is detected on the specified port. Your options are close, read and close, Sim
Banner, and SimStd Server.
The close option tells the rule to just terminate the connection. Read and close logs the
information and then terminates the connection. The SimStd Server and Sim Banner options
77
pertain to server emulation. The Sim Banner option allows you to perform a very simple
server emulation, such as what you might use to emulate an FTP server.
The Sim STD Server option allows you to emulate a more complex server, such as an IIS
server.
If you choose to use one of the sim options, you will have to fill in the simulator's name just
below the Time Out field.
The other part of the Action section that's worth mentioning is the severity section. KFSensor
treated some events as severe and other events as a more moderate threat. The dialog box's
Severity drop down list allows you to determine what level of severity should be associated
with the event that you are logging.
The final portion of the Add Listen dialog box is the Visitor DOS Attack Limits section. This
section allows you to prevent denial of service attacks against KFSensor. You can determine the
maximum number of connections to the machine per IP address (remember that this applies on a
per rule basis).
If your threshold is exceeded, you can choose to either ignore the excessive connections or
you can lock out the offending IP address.
Now that you have configured the new rule, select the Active Button to Enable/Disable. The
new rule should now be in effect.
RESULT:
Thus the program to explore automated attack and penetration tools has been completed
successfully
78
EX.No.: 11 DEFEATING MALWARE – ROOTKIT HUNTER
AIM
Root kit is a stealth type of malicious software designed to hide the existence of certain
process from normal methods of detection and enables continued privileged access to a computer.
79
80
81
VIVA QUESTIONS (PRE LAB and POSTLAB):
1. List any two web security threats.
2. List any two design goals for a firewall.
3. Define Security Mechanism.
4. What is S/MIME?
5. Define IPSec.
6. What are the key features of SET?
7. What is the use of public key encryption scheme?
8. Identify the possible threats for RSA algorithm.
9. List out the general schemes for the distribution of public keys.
10. What are the areas where Kerberos Version 5 addresses the limitation of Version 4?
82
RESULT:
Thus the Rootkits tool was installed and its various options were verified successfully
83
EX.No.: 12 TRIPLE DES
AIM:
ALGORITHM:
PROGRAM:
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.codec.binary.Base64;
public class TripleDESTest
{
public static void main(String[] args) throws Exception
{
String text = "textToEncrypt";
String codedtext = new TripleDESTest()._encrypt(text,"SecretKey");
String decodedtext = new TripleDESTest()._decrypt(codedtext,"SecretKey");
System.out.println(codedtext + " ---> " + decodedtext);
}
private String _encrypt(String message, String secretKey) throws Exception
{
MessageDigest md = MessageDigest.getInstance("SHA-1");
byte[] digestOfPassword = md.digest(secretKey.getBytes("utf-8"));
byte[] keyBytes = Arrays.copyOf(digestOfPassword, 24);
84
byte [] base64Bytes = Base64.encodeBase64(buf);
String base64EncryptedString = new String(base64Bytes);
return base64EncryptedString;
}
private String _decrypt(String encryptedText, String secretKey) throws Exception {
byte[] message = Base64.decodeBase64(encryptedText.getBytes("utf-8"));
MessageDigest md = MessageDigest.getInstance("SHA-1");
byte[] digestOfPassword = md.digest(secretKey.getBytes("utf-8"));
byte[] keyBytes = Arrays.copyOf(digestOfPassword, 24); SecretKey
key = new SecretKeySpec(keyBytes, "DESede");
OUTPUT:
85
VIVA QUESTIONS (PRELAB and POSTLAB):
1. Is Dsa Secure?
2. Is The Use Of Dsa Covered By Any Patents?
3. What Are Special Signature Schemes?
4. The DES algorithm has a key length of
5. In the DES algorithm, although the key size is 64 bits only 48bits are used for the
encryption procedure, the rest are parity bits.
6. The Initial Permutation table/matrix is of size
7. The number of unique substitution boxes in DES after the 48 bit XOR operation are
8. In the DES algorithm the 64 bit key input is shortened to 56 bits by ignoring every 4th bit.
True or False?
9. Which structure follows DES?
10. During decryption, we use the Inverse Initial Permutation (IP-1) before the IP. True or false?
11.A preferable cryptographic algorithm should have a good avalanche effect. True or false?
12.The number of tests required to break the DES algorithm are
13.The number of tests required to break the Double DES algorithm are
14.How many keys does the Triple DES algorithm use?
RESULT:
Thus the program to implement the TRIPLE DES in java has been executed and the output
was verified successfully.
86