龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 软件开发 > C/C++开发 >

自解密的加密程序的制作

时间:2009-12-22 15:42来源:未知 作者:admin 点击:
分享到:
为了保证自己的数据不被别人非法地窃取,有必要对数据文件进行适当地加密。本程序采取一定的算法,对密码和数据进行加密,生成一个自解密的EXE文件。这个自解密文件是由两部分

为了保证自己的数据不被别人非法地窃取,有必要对数据文件进行适当地加密。本程序采取一定的算法,对密码和数据进行加密,生成一个自解密的EXE文件。这个自解密文件是由两部分组成的。第一部分为可执行代码部分,其作用是对密码进行判定,对数据进行解密;后一部分是被加过密的密码和数据。

  

   本程序分两个模块进行编写。第一个是main.c,它是用来进行加密,产生EXE文件的;第二个是main2.c,它是用来解密的。分别对它们进行编译生成main.exe和main2.exe,再对其进行合并即可。

  

   合并方法如下:

  

   COPY /B main.EXE+main2.EXE Key.EXE(注重main.EXET和main2.EXE的顺序)

  

   使用时请按下列格式键入。

  

   Key〈欲加密文件〉〈产生后的EXE文件名〉

  

   按提示输入密码后将生成指定的可执行文件。解密时运行这个可执行文件。输入密码后(若输入三次都不正确,将退出解密程序),即把原文件内容还原到你指定的文件中。解密程序格式如下。

  

   可执行文件名 (filename)

  

   源程序如下:

  

   第一个源代码文件 main.c

  

   #include “stdio.h”

  

   main (int argc,char *argv[])

  

   {FILE *fp0, *fp1, *fp2;

  

   char ch,*passWord,i,str[10];password=str;

  

   if(argc!=3)

  

   {printf(“usage:key ");

  

   exit(0);

  

   }

  

   if((fp0=fopen(argv[0],“rb"))=NULL)

  

   {printf(“can`t open %s",argv[0]);

  

   exit(0)

  

   }

  

   if((fp1=fopen(argv[1],“r"))=NULL)

  

   {printf(“can`t open %s")argv[1]);

  

   exit(0);

  

   }

  

   if((fp2=fopen(argv[2],“wb"))=NULL)

  

   {printf(“can`t open %s",argv[2]);

  

   }

  

   password=(char *)getpass(“please input password:");

  

   fseek(fp0,1394OL,SEEK_SET);/* 13940是main.exe文件的长度,不同的工作环境会有不同的值。请以实际长度加以修改 */

  

   while(!feOf(fp0))

  

   fputc(fgetc(fp0),fp2);/*把main2.exe输入fp2指定的文件中*/

  

   for(i=0;password[i]!=`10`;i++)

  

   {fputc((i+password[i])&i,fp2);/*将密码加密后写入文件*/

  

   }

  

   fputc(`10`,fp2), /*将“10”放入密码后 */

  

   do{

  

   {for(i=0;password[i]!=`10`,i++

  

   {ch=fgetc(fp1) /*从欲加密文件读一个字符*/

  

   if(feof(fp1))break;

  

   ch=ch&password[i];

  

   ch+=i;

  

   ch=nch; /*将此字符同密码i值进行运算后写入fp2指定文件*/

  

   fputc(ch,fp2);

  

   }

  

   }While(!feof(fp1));

  

   fcloseal(c);

  

   }

  

   第二个源代码文件main2.c

  

   #include “stdio.h"

  

   #include “string.h"

  

   main(int argc,char *argv[])

  

   {FILE *FP0,*FP1;

  

   char *password,old password[10],str[10],ch,i;

  

   if(argc!=2)

  

   {printf(“Usage=%s",argv[0]);

  

   exit(o);

  

   }

  

   fseek(fp0,16888L,SEEK_SET); /*同理16888也视实际情况而定*/

  

   fgetc(fp0); /*读掉一个无效字符*/

  

   for(i=0;(oldpassword[i]=fget((fp0))!=`10`;i++)

  

   Oldpassword[i]=(oldpassword[i]&i)-i; /*对密码进行还原*/

  

   oldpassword[i]=`10`; /*把“10”藏于密码后 */

  

   password=(char *)getpass(“please input password:");

  

  

   for(i=0;i  {if(strcmp(password,oldpassword))

  

   {password=(ch *)getpass(“

  

password is wrong.

  

please input agai:");

  

   if(i==2)

  

   {printf(“

  

press any Key to exit……

  

");

  

   getch();exit(o)

  

   }

  

   }

  

   }/*对密码进行判定,有三次机会,都不正确则返回到操作系统*/

  

   do{

  

   for (i=0;password[i]!=`10`;i++)

  

   {ch=fgetc(fp0);

  

   if(feof(fp0))break;

  

   ch=nch;

  

   ch-=i;

  

   ch&=password[i];

  

   }

  

   }while(!feof(fp0);

  

   fcloseal(c);

  

   {

  

   上述程序在COMPAQ 586.TC2.0集成环境里通过。

  

精彩图集

赞助商链接