实验题目:字符串加密
键盘输入一个原始字符串作为明文,然后使用加密方法加密,再对加密字符串进行解密。样例如下图,加密方法自定,完成其功能并测试。
public class S5_1 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String orignal = "";
int key;
System.out.println("请输入一个明文字符串:");
orignal = in.nextLine();
System.out.println("明文:"+orignal);
System.out.println("请输入数字密钥:");
key = in.nextInt();
System.out.println("加密之后的密文是:");
System.out.println(Encryption.encryptionKaisa(orignal, key));
System.out.println("解密之后的明文是:");
System.out.println(Encryption.deencryptionKaisa(Encryption.encryptionKaisa(orignal, key),key));
}
}
class Encryption{
/***
* 使用凯撒加密方式加密数据
* 加密原理:将明文中的所有字母在字母表中向后或向前按照一定固定数目进行偏移后被替换成密文
* @param orignal 加密之前的明文
* @param key 密钥
* @return 加密后的字符
*/
public static String encryptionKaisa(String orignal, int key){
//将字符串转换为字符数组
char[] chars = orignal.toCharArray();
//构造字符串字符串缓冲区,其操作直接影响字符串本身,而不会产生副本
StringBuffer stringBuffer = new StringBuffer();
for (char ch:chars) {
//获取ASCII编码
int asscii = ch;
//使数据发生偏移
asscii += key;
//将偏移之后的数据转换为字符
char result = (char)asscii;
//将转换之后的字符进行拼接 append(String s)将指定字符串添加到字符串缓冲区,返回缓冲区本身
stringBuffer.append(result);
}
return stringBuffer.toString(); //返回字符串表示形式
}
/**
* 解密方式刚好与凯撒密码的加密方式相反
* @param encrytedData 加密之后的密文
* @param key 密钥
* @return 解密之后的明文
*/
public static String deencryptionKaisa(String encrytedData, int key){
//将字符串转换为字符数组
char[] chars = encrytedData.toCharArray();
//构造字符串字符串缓冲区,其操作直接影响字符串本身,而不会产生副本
StringBuffer stringBuffer = new StringBuffer();
for(char ch : chars){
//获取ASCII编码
int asscii = ch;
//使数据发生偏移
asscii -= key;
//将偏移之后的数据转换为字符
char result = (char)asscii;
//将转换之后的字符进行拼接 append(String s)将指定字符串添加到字符串缓冲区,返回缓冲区本身
stringBuffer.append(result);
}
return stringBuffer.toString(); //返回字符串表示形式
}
}
运行结果如下:
延伸:
尝试用按位左移(<<)或按位右移(>>)进行加密运算