-
Notifications
You must be signed in to change notification settings - Fork 19.9k
/
Copy pathAutokey.java
55 lines (42 loc) · 1.99 KB
/
Autokey.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package com.thealgorithms.ciphers;
/**
* The Autokey Cipher is an interesting and historically significant encryption method,
* as it improves upon the classic Vigenère Cipher by using the plaintext itself to
* extend the key. This makes it harder to break using frequency analysis, as it
* doesn’t rely solely on a repeated key.
* https://en.wikipedia.org/wiki/Autokey_cipher
*
* @author bennybebo
*/
public class Autokey {
// Encrypts the plaintext using the Autokey cipher
public String encrypt(String plaintext, String keyword) {
plaintext = plaintext.toUpperCase().replaceAll("[^A-Z]", ""); // Sanitize input
keyword = keyword.toUpperCase();
StringBuilder extendedKey = new StringBuilder(keyword);
extendedKey.append(plaintext); // Extend key with plaintext
StringBuilder ciphertext = new StringBuilder();
for (int i = 0; i < plaintext.length(); i++) {
char plainChar = plaintext.charAt(i);
char keyChar = extendedKey.charAt(i);
int encryptedChar = (plainChar - 'A' + keyChar - 'A') % 26 + 'A';
ciphertext.append((char) encryptedChar);
}
return ciphertext.toString();
}
// Decrypts the ciphertext using the Autokey cipher
public String decrypt(String ciphertext, String keyword) {
ciphertext = ciphertext.toUpperCase().replaceAll("[^A-Z]", ""); // Sanitize input
keyword = keyword.toUpperCase();
StringBuilder plaintext = new StringBuilder();
StringBuilder extendedKey = new StringBuilder(keyword);
for (int i = 0; i < ciphertext.length(); i++) {
char cipherChar = ciphertext.charAt(i);
char keyChar = extendedKey.charAt(i);
int decryptedChar = (cipherChar - 'A' - (keyChar - 'A') + 26) % 26 + 'A';
plaintext.append((char) decryptedChar);
extendedKey.append((char) decryptedChar); // Extend key with each decrypted char
}
return plaintext.toString();
}
}