回 帖 发 新 帖 刷新版面

主题:[讨论]文件加密技术一例


文件加密技术一例  

   



    给文件加密的技术很多,其中又分为不同等级,以适合不同场合的需要.这里给出最简单的文件加密技术,即采用文件逐字节与密码异或方式对
文件进行加密,当解密时,只需再运行一遍加密程序即可.

  下面是一个实例程序,能对任意一个文件进行加密,密码要求用户输入,限8位以内(当然你可以再更改).程序有很好的容错设计,这是我们应该
学习的.

/* Turbo 2.0 pass. give file a password! */

#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<string.h>

void dofile(char *in_fname,char *pwd,char *out_fname);/*对文件进行加密的具体函数*/

void main(int argc,char *argv[])/*定义main()函数的命令行参数*/
{
char in_fname[30];/*用户输入的要加密的文件名*/
char out_fname[30];
char pwd[8];/*用来保存密码*/

if(argc!=4){/*容错处理*/
printf("\nIn-fname:\n");
gets(in_fname);/*得到要加密的文件名*/

printf("Password:\n");
gets(pwd);/*得到密码*/

printf("Out-file:\n");
gets(out_fname);/*得到加密后你要的文件名*/


dofile(in_fname,pwd,out_fname);
}
else{/*如果命令行参数正确,便直接运行程序*/
strcpy(in_fname,argv[1]);
strcpy(pwd,argv[2]);
strcpy(out_fname,argv[3]);
dofile(in_fname,pwd,out_fname);
}

}


/*加密子函数开始*/
void dofile(char *in_fname,char *pwd,char *out_file)
{
FILE *fp1,*fp2;
register char ch;
int j=0;
int j0=0;

fp1=fopen(in_fname,"rb");
if(fp1==NULL){
printf("cannot open in-file.\n");
exit(1);/*如果不能打开要加密的文件,便退出程序*/
}
fp2=fopen(out_file,"wb");
if(fp2==NULL){
printf("cannot open or create out-file.\n");
exit(1);/*如果不能建立加密后的文件,便退出*/
}
while(pwd[++j0]);
ch=fgetc(fp1);

/*加密算法开始*/
while(!feof(fp1)){
fputc(ch^pwd[j>=j0?j=0:j++],fp2);/*异或后写入fp2文件*/
ch=fgetc(fp1);
}
fclose(fp1);/*关闭源文件*/
fclose(fp2);/*关闭目标文件*/
}

回复列表 (共6个回复)

沙发

请问这个程序是什么意思?
偶看不懂
我事初学者
哪个大虾能解释一下
运行过程中怎么加密!

板凳

不要急漫漫的看了啊

3 楼

char 改为无符号为好,要不字节头为1就要糟,
加密算法中,!feof(fp1)最好改如下,
先求得文章字节数后,把指针移回始位置,然后用for(long num0=0;num0<long; num0++遍
历。祝好运

4 楼

很好嘛,不过用Crypto++比找个呆子还容易
用FileSource,FileSink,IDEA接口,不用手工配置了,还安全高效

5 楼

再提醒:我们不是要这种程序,重要的是算法、技术和概念
不要以为XOR就万无一失。在我的机器上,它可以在0.03秒之内被破解!

6 楼

XOR当然容易被破,XOR加解密本身就是简单。两次XOR就得到本身了,实在笨点的就从01h~ffh去测试(应该没人会用0来XOR加密吧),两下三下就找到了

实际上这种方式不可靠

同样一个密码,来预先加密两个差不多文件(一个内容为'aaaa',一个内容为'aaab'),加密后,一下就可以发现,加密后的两个密文,就差一个字符。就可以确认是很简单的无关联性的密码加密

然后再换一个长度为1的密码,对上面的文件再加密,就完完全全可以找出使用的是什么算法了。(不管是xor还是用xor后在+多少)

当我的文件只差别一点的话,如上面'aaaa"与'aaab',同样一个密码,对他们加密后,形成的两个文件应该完全不相同,这个才是最基本的要求,也就是文件内容有关联性,也就是说只要改动文件一个小小的字符,那整个加密出来的文件就应该完全不一样。这样才起码的保证文件的安全。

我来回复

您尚未登录,请登录后再回复。点此登录或注册