Java Encryption/Decryption

Total Page:16

File Type:pdf, Size:1020Kb

Java Encryption/Decryption

Java Encryption/Decryption

For this project, you will need to use Java to implement a file encryption GUI using the substitution cipher and the one-time pad, which can be considered as examples of symmetric- key encryption (as opposed to asymmetric-key encryption). Additional features such as random key generators and identifying whether two files are the same are also part of this project.

1.) Substitution Cipher  For this project, you must support at the very minimum the printable ASCII characters (refer to https://en.wikipedia.org/wiki/ASCII. May find it easier to support all of the 256 ASCII values as your alphabet. If so, feel free to do so.

 For the project, you need to implement a method that takes as input the file to be encrypted/decrypted, the file to store the result of decrypting/encrypting the first file, and a file containing the randomly generated key consisting of at least the ASCII printable characters. I found it more straightforward to generate two separate keys that represent the table in the previous page as then you can the encryption/decryption method will be one and the same but with alternative representations of the key. Feel free to generate a single key if you wish, but note that by doing so your encryption and decryption procedures may need to be altered.

2. One-Time Pad  For the project, we also have another situation. In this situation, we no longer actually have a one-time pad but something more akin to the Vigenère cipher. Specifically, if the key is shorter than the plain text to be encrypted, we simply re-use it as many times as needed. For example, assuming that we have a key of length 6 as 101001  Note the repetition of the key when the key is shorter than the plain text to be encrypted. Also note how only part of the key is used at the end. Your code needs to support all possible situations regarding the key length:  Key length > Plain/Cipher text length  Key length = Plain/Cipher text length  Key length < Plain/Cipher text length

In Java, the smallest unit of memory that you can address is a byte. As such, you will simply perform the XOR on bytes as follows:  text[i] = (byte) (text[i] ^ key[i]);  Recall that the caret operator (^) performs XOR in Java. The caret operator, however, cannot be used on bytes directly. The bytes are automatically promoted to ints for you by Java. To get the byte back, you need to cast the int back to a byte. For your one-time pad, your code must be able to support any type of file as essentially you will be reading the files as byte streams anyway. Java Encryption/Decryption

3. Cryptographic Utilities

This class contains three major methods: a. A random key generator for the substitution file b. A random key generator for the one-time pad. c. A method to generate checksums for files

For the random key generator of the substitution file, you may choose to implement the method as taking two parameters, namely the files to hold the encryption and decryption keys. Whether you wish to pass two file streams or two Strings representing the names of the file is up to you (I chose the latter case for my own implementation and simply opened and closed the files within the method). Your code should at the very minimum generate a random key over all printable ASCII characters (all characters outside of this range should be printed as is). If you generate code for all 256 ASCII characters, that is fine. Clearly document which choice you make when designing your program. You may refer to https://en.wikipedia.org/wiki/ASCII and other resources regarding the ASCII character set.

One approach to generate the random key is to store your alphabet (the printable ASCII characters) in an array. You can then use the Fisher-Yates algorithm / Knuth shuffle to generate a random permutation of the array, which will then serve as the random key.

For the one time pad, this method takes two inputs. The first input is the name of the file to store the key. As you should have already seen above, the one-time pad serves as both the encryption and decryption keys. The second input represents the length of the one-time pad. Note that this length is passed as a long variable (int can only support files up to 2 GB). For this part, your key must be positive multiples of 1024. If the long passed is smaller than it, you need to increase it to the next positive multiple. For example, a key length of 1025 bytes simply becomes 2048 bytes. This method then randomly generates a key of the specified number of bytes to be stored in the file.

Finally, to generate the checksum of files, find some online implementation (you must cite the resource used) that allows you to generate the checksum of files. Feel free to choose whatever algorithm you like. Java easily supports MD5 and SHA-1 to mention a few. The checksum returned must be a String representing Hexadecimal digits. This is used to both display the checksum of a single file and to compare whether two files are equivalent.

Recommended publications