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

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

最简单的加密解密就是 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;
}
使用这个函数就可以让文件数据前后颠倒了 文件便无法运行了,再次执行这函数 数据颠倒过来后,就又可以运行了追问

运行后,出现必须定义入口点,,怎么回事啊?我用的是2010VS

追答

BOOL FileChange(char * path)

{
……………………
………………
}
int main()

{
char buff[250];
printf("请输入路径“);
scnaf("%s",&buff);
FileChange(buff);
}
大概这样

温馨提示:答案为网友推荐,仅供参考

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网