利用“^”异或运算对字符串进行加密
思路:1.先创建字符串输入的Scanner;
2.通过char[] array = password.toCharArray();// 获取字符数组;
3.遍历字符数组,按目前理解要用到遍历:数组所有元素进行访问,比如你要输出数组里所有的信息时,就要用到
4.进行异或运算
按位做“异或”运算是:位值相同得1,不同得0
例如:
< 加密过程:>
两者做“异或”结果为
< 解密过程:>
两者“异或”就得到了原文
详细代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
package com.lixiyu;
import java.util.Scanner;
public class Example {
public static void main(String[] args){
Scanner sca=new Scanner(System.in);
System.out.println("请输入一个英文字符串或解密字符串");
String line=sca.nextLine();//获取用户输入信息
char[] array=line.toCharArray();//获取字符数组
for (int i=0;i<array.length;i++){//历遍字符数组
array[i]=(char) (array[i]^20000);//对数组每个元素进行异或运算
}
System.out.println("加密解密结果如下:");
System.out.println(new String(array));//输出密钥
}
}
|
异或运算:
1 ^ 1 = 0
1 ^ 0 = 1
0 ^ 1 = 1
0 ^ 0 = 0
字符'A' 的ASCII编码为65 : 00000000 01000001
取整数7 : 00000000 00000000 00000000 00000111
XOR运算后 : 00000000 00000000 00000000 01000110
简单加密算法代码如下 :
public class Test { public static final int KEY = 7; public static void main(String[] args) { String str = "Hello World!"; StringBuffer str2 = new StringBuffer(); //存储加密后的字符串 StringBuffer str3 = new StringBuffer(); //存储解密后的字符串 //加密过程 for(int i=0;i<str.length();i++) { char c = (char)(str.charAt(i) ^ KEY); str2.append(c); } //解密过程 for(int i=0;i<str2.length();i++) { char c = (char)(str2.charAt(i) ^ KEY); str3.append(c); } System.out.println("原始 的字符串为:" + str); System.out.println("加密后 的字符串为:" + str2); System.out.println("解密后 的字符串为:" + str3); } }
输出:
原始 的字符串为:Hello World!
加密后 的字符串为:Obkkh'Phukc&
解密后 的字符串为:Hello World!