主要利用了异或运算的如下特性:
a ^ b ^ b = a ^ (b ^ b) = a ^ 0 = a;
b ^ b,由于每个位都是相同的,所以 b ^ b = 0;
而和 0 异或,值不变,因此 a ^ 0 = a。
也就是说可以将一个文件的每一字节都和一个数异或一次,则可以加密文件;再异或一次,则可以解密文件。
public static void encryptFile(String file){
byte[] buffer = new byte[1024];
try (FileInputStream fin = new FileInputStream(file);
FileOutputStream fout = new FileOutputStream(file + ".e")) {
int x = 0;
while (fin.available() > 0) {
int n = fin.read(buffer);
for (int i = 0; i < n; i++) {
buffer[i] ^= (x = (x + 1) % 9997); //异或加密
}
fout.write(buffer, 0, n);
}
} catch (IOException e) {
e.printStackTrace();
}
try {
Files.delete(Paths.get(file));
Files.move(Paths.get(file + ".e"), Paths.get(file));
} catch (Exception e) {
e.printStackTrace();
}
}
本文深入探讨了异或运算在文件加密与解密中的应用,详细解析了其核心原理:通过与一个特定数值进行异或操作,实现文件内容的加密;再次异或同一数值则可恢复原文件。文章提供了具体的Java代码示例,展示了如何实现文件的加密与解密过程。
240

被折叠的 条评论
为什么被折叠?



