自解密加密程序製作

爲了保證自己的數據不被別人非法地竊取,有必要對數據文件進行適當地加密。本程序採取一定的算法,對密碼和數據進行加密,生成一個自解密的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集成環境裏通過。 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章