Delphi“流”实现文件加密器

http://tech.ddvip.com   2006年07月31日    社区交流

本文详细介绍Delphi“流”实现文件加密器

  在对文件进行加密时,先执行程序AddEncrypt,选择需要加密的exe文件,并在password中输入加密密码,点击"加密"按钮。源exe文件将被同名密文取代。解密时,执行加密程序,会弹出对话框询问密码,用户输入密码后,如密码正确则程序正常运行,否则程序将报错,无法运行。需要注意的是,上面的程序只不过简单地把一个文件添加到另一个文件的尾部,实际应用中可改成添加多个文件,实现过程中只要根据实际大小和个数定义好偏移地址就可以了。因为篇幅有限,文中只给出了源程序的关键代码,有兴趣的读者可自行扩弃完善。源程序清单如下:

  Function Jmf_AddtoFile(SourceFile,PassWord,TargetFile:String):Boolean;
 Var
  Target,Source:TFileStream;
  MyFileSize,PassWordSize:integer;
 Begin
  Try
   Source:=TFileStream.Create(SoureceFile,fmOpenRead or fmShareExclusive);
   Target:=TFileStream.Create(TargetFile,fmOpenWrite of fmShareExclusive);
   Try
    Target.Seek(0,soFromEnd);{往尾部添加资源}
    Target.CopyFrom(Source,0);
    MyFileSize:=Source.Size++Sizeof(MyFileSize);{计算资源大小,并写入辅程尾部}
    Target.WriteBuffer(MyFilesSize,sizefo(MyFileSize));
    PassWordSize:=Sizeof(PassWord)+sizeof(PassWordSize);
    Target.Seek(0,soFromEnd);
    Target.WriteBuffer(PassWord,Sizeof(PassWord));
    Target.WriteBuffer(PassWordSize,sizeof(PassWordSize));
   Finally
    Target.Free;
    Source.Free;
   End;
   Except
    Result:=False;
    Exit;
   End;
  Reslut:=True;
  End;
Function Jmf_LoadFromFile(SourceFile,TargetFile:string):Boolean;
 Var Source:TFileStream;
  Target:TmemoryStream;
  MyFilesize,Position:integer;
 Begin
  Try
   Target:=TmemoryStream.Create;
   Source:=TFileStream(SourceFile,fmOpenRead or fmShareDenyNone);
   Try
    Source.Seek(-sizeof(Position),soFromEnd);
    Source.ReadBuffer(Position,sizeof(Position));
    Source.Seek(-Position-sizefo(MyFileSize),soFromEnd);
    Source.ReadBuffer(MyFileSize,sizeof(MyFileSize));{读出资源大小}
    Source.Seek(-Position-MyFileSize,soFromEnd);{定位到资源位置}
    Target.CopyFrom(Source,MyFileSize-sizefo(MyFileSize));{取出资源}
    Target.SaveToFile(TargetFile);{存放到文件}
   finally
    Target.Free;
    Source.Free;
   end;
  except
   Result:=false;
   Exit;
  end;
  Result:=true;
 end;
Function Jmf_PassFromFile(var password:string;SourceFile:string):Boolean;
 Var
  Source:TFileStream;
  PassWordSize:interger;
 Begin
  Try
   Source:=TFileStream.Create(SourceFile,fmOpenRead or fmShareDenyNone);
  Try
   Source.Seek(0,soFromEnd);{定位到资源位置}
   Source.Read(PassWordSize,Sizeof(PassWordSize));
   Source.Seek(-PassWordSize,soFromEnd);
   Source.Read(PassWord,PassWordSize-Sizeof(PassWordSize));
  Finally
   Source.Free;
  End;
  Except
   Result:=false;
  Exit;
 End;
  Result:=true;
 End;
Procedure Tfom1.unbindClick(Sender:TObject);
 Var
  S:string;
  pass,inpass:string;
 begin
  inpass:=password.text;
  S:=ChangeFileExt(Application.ExeName,'Jmf');
  If Jmf_PassFromFile(pass,Application.ExeName) then
   If pass=password.text then
   Begin
    Jmf_LordFromFile(Application.ExeName,S);{取出文件保存在当前路径下并命名"原文件.Jmf"}
    Winexec(pchar(S),SW_Show);{运行"原文件.Jmf"}
    Application.Terminate;{退出程序}
   end
  else
   Application.MessageBox('密码错误,重新输入!','密码错误',MB_OK);
  end;
Procedure Tform1.openClick(Sender:TObject);
 begin
  If OpenDialog1.Execute then position.Text:=OpenDialog1.FileName;
 end;
procedure Tform1.secretClick(Sender:TObject);
 var s:string;
  spass:string;
 begin
  s:=ExtractFilePath(position.text);
  spass:=pass.Text;
  if ExtractRes('exefile','head',s+'head.exe') then
   if Jmf_AddtoFile(position.text,s+'head.exe',spass) then
    if DeleteFile(position.text)then
     if RenameFile(s+'head.exe',position.text)then
      Application.MessageBox('文件加密成功!!','信息',MB_OK)
     Else
      Begin
       If FileExists(s+'head.exe')
        then DeleteFile(S+'head.exe');
         Application.MessageBox('文件加密失败!!','信息',MB_OK)
       end;
Function ExtractRes(Restype,Resname,ResNewName:string):Boolean;
 Var Res:TresourceStream;
 begin
 try
  Res:=TresourceStream.Create(Hinstance,Resname,Pchar(ResType));
  try
   Res.SaveToFile(ResNewName);
   Result:=true;
  Finally
   Res.Free;
  end;
  except
   Result:=False;
 end;

  三、小结

  本文论述了exe文件加密的方法,它的实现原理与文件捆绑机的道理是一致的,就是把两个或者多个程序添加到一个头文件里面,自解压程序和安装程序的原理也是一样的,只需在文件添加和文件读取时,调用解压缩程序就可以了。

作者:文浩    责编:豆豆技术应用

正在加载评论...