Java 中的凯撒密码加密
凯撒密码是执行加密的最简单方法之一。本教程演示如何在 Java 中使用 Caesar Cipher 执行加密和解密。
Java 中的凯撒密码
凯撒密码是最早的加密方法之一。它可以用任何编程语言实现。算法简单;例如,如果我们对文本 delftstack
执行加密,Caesar Cipher 算法将通过将字符替换为按字母顺序排列在字符下方的固定位置来加密文本。
我们传递一个整数密钥,以决定我们要在加密字符时向下多少个位置。
例如,如果文本是 ABCD
并且密钥是 2,则加密的文本将是 CDEF
。让我们尝试在 Java 中实现 Caesar Cipher 加密方法。
Java 中的凯撒密码加密
下面的代码演示了 Java 中 Caesar Cipher 加密的实现。
package delftstack;
import java.util.Scanner;
public class Caesar_Cipher_Encrypt {
public static void main(String...s){
String Original_Message, Encrypted_Message = "";
int Cipher_Key;
char Message_Char;
Scanner sc = new Scanner(System.in);
System.out.println("Please enter a message: ");
Original_Message = sc.nextLine();
System.out.println("Enter the key: ");
Cipher_Key = sc.nextInt();
for(int i = 0; i < Original_Message.length(); ++i){
Message_Char = Original_Message.charAt(i);
if(Message_Char >= 'a' && Message_Char <= 'z'){
Message_Char = (char)(Message_Char + Cipher_Key);
if(Message_Char > 'z'){
Message_Char = (char)(Message_Char - 'z' + 'a' - 1);
}
Encrypted_Message += Message_Char;
}
else if(Message_Char >= 'A' && Message_Char <= 'Z'){
Message_Char = (char)(Message_Char + Cipher_Key);
if(Message_Char > 'Z'){
Message_Char = (char)(Message_Char - 'Z' + 'A' - 1);
}
Encrypted_Message += Message_Char;
}
else {
Encrypted_Message += Message_Char;
}
}
System.out.println("The Encrypted Message is : " + Encrypted_Message);
}
}
上面的代码实现了 Caesar Cipher 加密方法。查看输出:
Please enter a message:
This is delftstack.com
Enter the key:
3
The Encrypted Message is : Wklv lv ghoiwvwdfn.frp
Java 中的凯撒密码解密
解密将是反之亦然的操作。请参阅使用 Caesar Cipher 方法的解密实现。
package delftstack;
import java.util.Scanner;
public class Caesar_Cipher_Decrypt {
public static void main(String...s){
String Original_Message, Decrypted_Message = "";
int Cipher_Key;
char Message_Char;
Scanner sc = new Scanner(System.in);
System.out.println("Please enter an encrypted message: ");
Original_Message = sc.nextLine();
System.out.println("Enter the key: ");
Cipher_Key = sc.nextInt();
for(int i = 0; i < Original_Message.length(); ++i){
Message_Char = Original_Message.charAt(i);
if(Message_Char >= 'a' && Message_Char <= 'z'){
Message_Char = (char)(Message_Char - Cipher_Key);
if(Message_Char < 'a'){
Message_Char = (char)(Message_Char + 'z' - 'a' + 1);
}
Decrypted_Message += Message_Char;
}
else if(Message_Char >= 'A' && Message_Char <= 'Z'){
Message_Char = (char)(Message_Char - Cipher_Key);
if(Message_Char < 'A'){
Message_Char = (char)(Message_Char + 'Z' - 'A' + 1);
}
Decrypted_Message += Message_Char;
}
else {
Decrypted_Message += Message_Char;
}
}
System.out.println("The Decrypted Message is : " + Decrypted_Message);
}
}
上面的代码在 Java 中实现了 Caesar Cipher 解密。查看输出:
Please enter an encrypted message:
Wklv lv ghoiwvwdfn.frp
Enter the key:
3
The Decrypted Message is : This is delftstack.com
相关文章
如何在 Java 中延迟几秒钟的时间
发布时间:2023/12/17 浏览次数:217 分类:Java
-
本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。
如何在 Java 中把 Hashmap 转换为 JSON 对象
发布时间:2023/12/17 浏览次数:187 分类:Java
-
它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。
如何在 Java 中按值排序 Map
发布时间:2023/12/17 浏览次数:171 分类:Java
-
本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map
进行排序,并列出了一些示例代码来理解它。
如何在 Java 中打印 HashMap
发布时间:2023/12/17 浏览次数:192 分类:Java
-
本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。
在 Java 中更新 Hashmap 的值
发布时间:2023/12/17 浏览次数:146 分类:Java
-
本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。
Java 中的 hashmap 和 map 之间的区别
发布时间:2023/12/17 浏览次数:79 分类:Java
-
本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,
在 Java 中获取用户主目录
发布时间:2023/12/17 浏览次数:218 分类:Java
-
这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。
Java 中 size 和 length 的区别
发布时间:2023/12/17 浏览次数:179 分类:Java
-
这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。
Java 中的互斥锁
发布时间:2023/12/17 浏览次数:111 分类:Java
-
了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,