算法二:异或加密,可以对任意文件加密。
#include <iostream>
#include <fstream>
using namespace std;
int main()
{
ifstream iFile;
iFile.open("D:\\测试1.mp3", ios::in | ios::binary); //以二进制的形式打开文件 类似于C语言中rb
iFile.seekg(0, ios::end);
int nFileLen = iFile.tellg();
iFile.seekg(0, ios::beg);
char *str = new char[nFileLen + 1];
iFile.read(str, nFileLen);
iFile.close();
str[nFileLen] = 0;
char *secret = "leowait"; //设置加密密码
int nLen = (int)strlen(secret);
int j = 0;
for (int i = 0; i < nFileLen; i++)
{
str[i] ^= secret[j];
j++;
if (j >= nLen)
j -= nLen;
}
ofstream oFile("D:\\测试2.mp3", ios::out | ios::binary);
oFile.write(str, nFileLen);
oFile.close();
delete[] str;
str = nullptr;
return 0;
}
原理就是将文件字节数赋值给nFileLen,然后与设置的密码进行循环二进制异或操作,最终生成的文件无法打开,即使打开也会乱码。
理解了原理,代码就很容易理解了,唯一解释一点。
char *secret = "leowait"; //设置加密密码
int nLen = (int)strlen(secret);
int j = 0;
for (int i = 0; i < nFileLen; i++)
{
str[i] ^= secret[j];
j++;
if (j >= nLen)
j -= nLen;
}
一般来说,文件字节长度一般都比设置的密码长度长,因此当密码的最后一位异或后,密码就要循环到第一位在与文件异或。
因此我们需要加个判断条件。
更多推荐
文件加密(二) 异或加密
发布评论