在密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密、恺撒变换、变换加密,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。
例如输入明文:HelloWorld 偏移量为3
此时输出密文:KhoorZruog
以下是用java代码实现凯撒密码的加密解密:
//凯撒密码:
//输入明文:abc 输入密钥:2
//输出密文:cde
import java.util.Scanner;
public class KaiSaPassWord {
public static void main(String[] args) {
System.out.print("请输入密文:");
Scanner scanner = new Scanner(System.in);
String string=scanner.next();
System.out.print("请输入秘钥:");//秘钥即偏移量
int key=scanner.nextInt();
key=key%26;//key的绝对值可能会大于26
System.out.println("-------------------------");
System.out.print("明文是:");
char ch[]=string.toCharArray();//将字符串转换为字符数组
for (int i = 0; i < ch.length; i++) {
if (ch[i]>='a'&&ch[i]<='z') {
ch[i] = (char)(((ch[i]-'a')+key)%26+'a');
}
else if(ch[i]>='A'&&ch[i]<='Z'){
ch[i] = (char)(((ch[i]-'A')+key)%26+'A');
}
System.out.print(ch[i]);
}
}
}
版权归原作者 想学网安的小白 所有, 如有侵权,请联系我们删除。