文件加密(二) 异或加密

算法二:异或加密,可以对任意文件加密。


#include 
#include 
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,然后与设置的密码进行循环二进制异或操作,最终生成的文件无法打开,即使打开也会乱码。



文件加密(二) 异或加密_第1张图片


文件加密(二) 异或加密_第2张图片


         理解了原理,代码就很容易理解了,唯一解释一点。

	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;
	}

            一般来说,文件字节长度一般都比设置的密码长度长,因此当密码的最后一位异或后,密码就要循环到第一位在与文件异或。

因此我们需要加个判断条件。



你可能感兴趣的:(数据结构与算法)