本文目录一览:
- 1、异或加密与解密(C语言)注释
- 2、设计一种很难被破解的异或加密方法??
- 3、关于用异或位来加密数据 那该怎么破解呢
- 4、异或算法的密钥破解,知道密文和明文 ,可以求密钥吗?已知是异或加密的,写个原理也好的。
- 5、如何利用异或运算进行简单加密解密
异或加密与解密(C语言)注释
异或运算有一个特性
若
c = a xor b
那么
a = c xor b
根据这样的特性,你有一个信息a,然后你产生一个密码b,把它和a异或运算之后就变成了c。这就是一种加密,解密的时候,把c重新和b异或运算,就变回了a。
顺带说一下,异或是很弱的加密方法,很容易被破解的。
设计一种很难被破解的异或加密方法??
按现在的cpu速度,哪怕不用电脑,用现在手机的cpu都绝对可以在1秒内破解出来,这个所谓的加密操作实际上等于0 除非你的文件内容原文就是不可读的(这样不管破解成功还是失败,破解者都没法知道,即使成功了看见的解密结果也是个乱码。。。囧。。所以不可能破解到) 异或加密是强度极低的一种方式,除非极长的密钥,希望获得比较靠谱的加密,还是分组交换式加密方案可取,比如DES加密。
关于用异或位来加密数据 那该怎么破解呢
这不存在什么暴力破解
而且这种加密也没什么实际意义。因为虽然这种方式没法破解, 但是你要保存的是同样长的一段密码, 这跟保存一段原文没什么区别
异或算法的密钥破解,知道密文和明文 ,可以求密钥吗?已知是异或加密的,写个原理也好的。
可以。
比如:明文(如1111)⊕密钥(如1001)得到密文(如0110)
然后拿密文(0110)⊕明文(1111)就得密钥(1001)
如何利用异或运算进行简单加密解密
利用“^”异或运算对字符串进行加密
思路:1.先创建字符串输入的Scanner;
2.通过char[] array = password.toCharArray();// 获取字符数组;
3.遍历字符数组,按目前理解要用到遍历:数组所有元素进行访问,比如你要输出数组里所有的信息时,就要用到
4.进行异或运算
按位做“异或”运算是:位值相同得1,不同得0
例如:
加密过程:
原解释的二进制为 1 1 0 0 ----原文
设定的key的二进制为 0 1 1 0 ----密匙
两者做“异或”结果为 0 1 0 1 ----密文
解密过程:
0 1 0 1----密文
0 1 1 0----密匙
两者“异或”就得到了原文 1 1 0 0 ----原文
详细代码:
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;iarray.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;istr.length();i++)
{
char c = (char)(str.charAt(i) ^ KEY);
str2.append(c);
}
//解密过程
for(int i=0;istr2.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!