編寫(xiě)自解密程序
為了保證自己的數(shù)據(jù)不被別人非法地竊取,有必要對(duì)數(shù)據(jù)文件進(jìn)行適當(dāng)?shù)丶用?。?a class="contentlabel" href="http://2s4d.com/news/listbylabel/label/程序">程序采取一定的算法,對(duì)密碼和數(shù)據(jù)進(jìn)行加密,生成一個(gè)自解密的EXE文件。這個(gè)自解密文件是由兩部分組成的。第一部分為可執(zhí)行代碼部分,其作用是對(duì)密碼進(jìn)行判斷,對(duì)數(shù)據(jù)進(jìn)行解密;后一部分是被加過(guò)密的密碼和數(shù)據(jù)。
本文引用地址:http://2s4d.com/article/148822.htm本程序分兩個(gè)模塊進(jìn)行編寫(xiě)。第一個(gè)是main.c,它是用來(lái)進(jìn)行加密,產(chǎn)生EXE文件的;第二個(gè)是main2.c,它是用來(lái)解密的。分別對(duì)它們進(jìn)行編譯生成main.exe和main2.exe,再對(duì)其進(jìn)行合并即可。
合并方法如下:
COPY /B main.EXE+main2.EXE Key.EXE(注意main.EXET和main2.EXE的順序)
使用時(shí)請(qǐng)按下列格式鍵入。
Key〈欲加密文件〉〈產(chǎn)生后的EXE文件名〉
按提示輸入密碼后將生成指定的可執(zhí)行文件。解密時(shí)運(yùn)行這個(gè)可執(zhí)行文件。輸入密碼后(若輸入三次都不正確,將退出解密程序),即把原文件內(nèi)容還原到你指定的文件中。解密程序格式如下。
可執(zhí)行文件名 (filename)
源程序如下:
第一個(gè)源代碼文件 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文件的長(zhǎng)度,不同的工作環(huán)境會(huì)有不同的值。請(qǐng)以實(shí)際長(zhǎng)度加以修改 */
while(!feOf(fp0))
fputc(fgetc(fp0),fp2);/*把main2.exe輸入fp2指定的文件中*/
for(i=0;password[i]!=`10`;i++)
{fputc((i+password[i])I,fp2);/*將密碼加密后寫(xiě)入文件*/
}
fputc(`10`,fp2), /*將“10”放入密碼后 */
do{
{for(i=0;password[i]!=`10`,i++
{ch=fgetc(fp1) /*從欲加密文件讀一個(gè)字符*/
if(feof(fp1))break;
評(píng)論