用fopen,fclose,fseek,ftell,fwrite,fread,这些函数写一个加密解密的代码

2024-11-27 16:47:21
推荐回答(1个)
回答1:

最简单的加密解密就是 fopen打开要加密的文件,fseek+ftell得到文件大小,之后fread读取全部数据,将数据分为2半,前后颠倒,在用fwrite清空原先文件数据 并写入颠倒后的数据 这样就实现了简单的不能再简单的加密了,反之亦然。
BOOL FileChange(char * path)
{
long length;
long last;
FILE * fc=fopen(path,"rb");
if(NULL==fc)
return 0;
fseek(fc,0,SEEK_END);
length=ftell(fc);
if((length%2)==0)
{
last=length-(length/2);
fseek(fc,0,SEEK_SET);
char *jo=(char *)malloc(length-last);
char *jo1=(char *)malloc(last);
fread(jo,length-last,1,fc);
fseek(fc,length-last,SEEK_SET);
fread(jo1,last,1,fc);
fclose(fc);
FILE * fw=fopen(path,"wb+");
fwrite(jo1,last,1,fw);
fwrite(jo,length-last,1,fw);
fclose(fw);
}
else
{
length--;
last=length-(length/2);
fseek(fc,0,SEEK_SET);
char *jo=(char *)malloc(length-last);
char *jo1=(char *)malloc(last);
char *jo2=(char *)malloc(1);
fread(jo,length-last,1,fc);
fseek(fc,length-last,SEEK_SET);
fread(jo1,last,1,fc);
fread(jo2,1,1,fc);
fclose(fc);
FILE * fw=fopen(path,"wb+");
fwrite(jo1,last,1,fw);
fwrite(jo,length-last,1,fw);
fwrite(jo2,1,1,fw);
free(jo);
free(jo1);
free(jo2);
fclose(fw);
}
return 0;
}
使用这个函数就可以让文件数据前后颠倒了 文件便无法运行了,再次执行这函数 数据颠倒过来后,就又可以运行了