可以考虑用Hook技术解决。查查这方面的资料吧。

解决方案 »

  1.   

    二、实际应用之一:利用流制作EXE文件加密器、捆绑、自解压文件及安装程序  我们先来说一下如何制作一个EXE文件加密器吧。 
      EXE文件加密器的原理:建立两个文件,一个用来添加资源到另外一个EXE文件里面,称为添加程序。另外一个被添加的EXE文件称为头文件。该程序的功能是把添加到自己里面的文件读出来。Windows下的EXE文件结构比较复杂,有的程序还有校验和,当发现自己被改变后会认为自己被病毒感染而拒绝执行。所以我们把文件添加到自己的程序里面,这样就不会改变原来的文件结构了。我们先写一个添加函数,该函数的功能是把一个文件当作一个流添加到另外一个文件的尾部。函数如下:Function Cjt_AddtoFile(SourceFile,TargetFile:string):Boolean;
    var
    Target,Source:TFileStream;
    MyFileSize:integer;
    begin
    try
    Source:=TFileStream.Create(SourceFile,fmOpenRead or fmShareExclusive);
    Target:=TFileStream.Create(TargetFile,fmOpenWrite or fmShareExclusive);
    try
    Target.Seek(0,soFromEnd);//往尾部添加资源
    Target.CopyFrom(Source,0);
    MyFileSize:=Source.Size+Sizeof(MyFileSize);//计算资源大小,并写入辅程尾部
    Target.WriteBuffer(MyFileSize,sizeof(MyFileSize));
    finally
    Target.Free;
    Source.Free;
    end;
    except
    Result:=False;
    Exit;
    end;
    Result:=True;
    end;
    有了上面的基础,我们应该很容易看得懂这个函数。其中参数SourceFile是要添加的文件,参数TargetFile是被添加到的目标文件。比如说把a.exe添加到b.exe里面可以:Cjt_AddtoFile('a.exe',b.exe');如果添加成功就返回True否则返回假。
    根据上面的函数我们可以写出相反的读出函数:
    Function Cjt_LoadFromFile(SourceFile,TargetFile :string):Boolean;
    var
    Source:TFileStream;
    Target:TMemoryStream;
    MyFileSize:integer;
    begin
    try
    Target:=TMemoryStream.Create;
    Source:=TFileStream.Create(SourceFile,fmOpenRead or fmShareDenyNone);
    try
    Source.Seek(-sizeof(MyFileSize),soFromEnd);
    Source.ReadBuffer(MyFileSize,sizeof(MyFileSize));//读出资源大小
    Source.Seek(-MyFileSize,soFromEnd);//定位到资源位置
    Target.CopyFrom(Source,MyFileSize-sizeof(MyFileSize));//取出资源
    Target.SaveToFile(TargetFile);//存放到文件
    finally
    Target.Free;
    Source.Free;
    end;
    except
    Result:=false;
    Exit;
    end;
    Result:=true;
    end;
      其中参数SourceFile是已经添加了文件的文件名称,参数TargetFile是取出文件后保存的目标文件名。比如说Cjt_LoadFromFile('b.exe','a.txt');在b.exe中取出文件保存为a.txt。如果取出成功就返回True否则返回假。
    打开Delphi,新建一个工程,在窗口上放上一个Edit控件Edit1和两个Button:Button1和Button2。Button的Caption属性分别设置为“确定”和“取消”。在Button1的Click事件中写代码:
    var S:string;
    begin
    S:=ChangeFileExt(Application.ExeName,'.Cjt');
    if Edit1.Text='790617' then 
    begin
    Cjt_LoadFromFile(Application.ExeName,S);
    {取出文件保存在当前路径下并命名"原文件.Cjt"}
    Winexec(pchar(S),SW_Show);{运行"原文件.Cjt"}
    Application.Terminate;{退出程序}
    end
    else 
    Application.MessageBox('密码不对,请重新输入!','密码错误',MB_ICONERROR+MB_OK);
      编译这个程序,并把EXE文件改名为head.exe。新建一个文本文件head.rc,内容为: head exefile head.exe,然后把它们拷贝到Delphi的BIN目录下,执行Dos命令Brcc32.exe head.rc,将产生一个head.res的文件,这个文件就是我们要的资源文件,先留着。
      我们的头文件已经建立了,下面我们来建立添加程序。
      新建一个工程,放上以下控件:一个Edit,一个Opendialog,两个Button1的Caption属性分别设置为"选择文件"和"加密"。在源程序中添加一句:{$R head.res}并把head.res文件拷贝到程序当前目录下。这样一来就把刚才的head.exe跟程序一起编译了。
      在Button1的Cilck事件里面写下代码:
    if OpenDialog1.Execute then Edit1.Text:=OpenDialog1.FileName;
      在Button2的Cilck事件里面写下代码:
    var S:String;
    begin
    S:=ExtractFilePath(Edit1.Text);
    if ExtractRes('exefile','head',S+'head.exe') then
    if Cjt_AddtoFile(Edit1.Text,S+'head.exe') then
    if DeleteFile(Edit1.Text) then
    if RenameFile(S+'head.exe',Edit1.Text) then
    Application.MessageBox('文件加密成功!','信息',MB_ICONINFORMATION+MB_OK)
    else
    begin
    if FileExists(S+'head.exe') then DeleteFile(S+'head.exe');
    Application.MessageBox('文件加密失败!','信息',MB_ICONINFORMATION+MB_OK)
    end;
    end;
    其中ExtractRes为自定义函数,它的作用是把head.exe从资源文件中取出来。
    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;
    end;
       注意:我们上面的函数只不过是简单的把一个文件添加到另一个文件的尾部。实际应用中可以改成可以添加多个文件,只要根据实际大小和个数定义好偏移地址就可以了。比如说文件捆绑机就是把两个或者多个程序添加到一个头文件里面。那些自解压程序和安装程序的原理也是一样的,不过多了压缩而已。比如说我们可以引用一个LAH单元,把流压缩后再添加,这样文件就会变的很小。读出来时先解压就可以了。另外,文中EXE加密器的例子还有很多不完善的地方,比如说密码固定为"790617",取出EXE运行后应该等它运行完毕后删除等等,读者可以自行修改。
      

  2.   

    procedure TForm1.FormCreate(Sender: TObject);
    begin
    form4:=Tform4.Create(Self);
    form4.ShowModal;
    form4.Release;
    form1.ShowHint:=true;
    Application.OnHint := DisplayHint;
    Application.ShowHint := True;
    end;
    procedure TForm4.BitBtn1Click(Sender: TObject);
    begin
    if (table1.FindKey([Edit2.text])) and (Edit2.text=table1.FieldByName('用户名').asstring) and (edit1.Text=table1.FieldByName('密码').asstring) then
    begin
    Form1.N6.Enabled:=true;
    Form1.N7.Enabled:=true;
    end
    else
    begin
    Application.MessageBox('用户名或密码错误!','错误信息提示', 0);
    Form1.N6.Enabled:=false;
    Form1.N7.Enabled:=false;
    end;
    end;
    procedure TForm4.FormCreate(Sender: TObject);
    begin
    database1.params.values['username']:='sa';
    database1.params.values['password']:='123';
    database1.LoginPrompt:=false;
    table1.Active:=true;end;
      

  3.   

    上面的所谓EXE加密不可靠的好的方法就是写PE Shell,就是写PE的壳,100% ASM代码就能OK
    修改OEP指向你的Entry Point,新建Import Table
    壳中处理旧的Import Table然后JMP到OEP就OK了具体方法是商业秘密哦:)呵呵我就为一家加密狗公司开发了这样的加壳程序:)http://lysoft.7u7.net
      

  4.   

    你用EXE加密方法可以的。代码可以在Delphibox找到。
    如果需要壳的方法。你也可以到这里下载ASM的源码:
    http://www.pediy.com/code/Protectors/yoda%27s%20Crypter/yc12.zip
      

  5.   

    biku(Biku)
    是指任何一个我指定不能使用的程序,