最为简单的加密方式,这里基本思想是把一串数据和密码扔进去,使用密码对数据依次异或。
考虑到密码一般都比数据短,这里将密码反复使用。
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];
}