zoukankan      html  css  js  c++  java
  • 读写另一EXE的内存

    procedure TfrmMain.tmrChangeServerNameTimer(Sender: TObject);
    function GetProcessID(FileName: string = ''): TProcessEntry32;
    var
      Ret: BOOL;
      s: 
    string;
      FSnapshotHandle: THandle;
      FProcessEntry32: TProcessEntry32;
    begin
      FSnapshotHandle :
    = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
      FProcessEntry32.dwSize :
    = Sizeof(FProcessEntry32);
      Ret :
    = Process32First(FSnapshotHandle, FProcessEntry32);
      
    while Ret do
      
    begin
        s :
    = ExtractFileName(FProcessEntry32.szExeFile);
        
    if (AnsiCompareText(Trim(s),Trim(FileName))=0and (FileName <> ''then begin
          result :
    = FProcessEntry32;
          
    break;
        
    end;
        Ret :
    = Process32Next(FSnapshotHandle, FProcessEntry32);
      
    end;
      CloseHandle(FSnapshotHandle);
    end;
    var
      FProcessEntry32: TProcessEntry32;
      ProcessID: integer;
      ProcessHandle: THandle;
      lpBuffer: PChar;
      nSize: DWORD;
      lpNumberOfBytes: DWORD;
      mbi_thunk:TMemoryBasicInformation;
      dwOldProtect:dword;
    const
      LeftAddress 
    = $02370C68;
      RightAddress1 
    = $02370C74;
      RightAddress2 
    = $02370C84;
    //  ServerName = '京信三国';
    begin
      FProcessEntry32 :
    = GetProcessID('aLogin.exe');
      
    if FProcessEntry32.th32ProcessID =0 then exit;
      ProcessID :
    = FProcessEntry32.th32ProcessID;
      ProcessHandle :
    = OpenProcess(PROCESS_ALL_ACCESS, false, ProcessID);
      
    //---------------写left
      lpBuffer :
    = PChar(GB2Big5('01.' + ServerName));
      nSize:
    = 12;                               //N是数据长度
      
    //写LeftAddress数据
      VirtualQueryEx(ProcessHandle,Pointer(LeftAddress),mbi_thunk, sizeof(TMemoryBasicInformation));
      VirtualProtectEx(ProcessHandle,Pointer(LeftAddress),nSize,PAGE_EXECUTE_READWRITE,mbi_thunk.Protect);
      WriteProcessMemory(ProcessHandle, Pointer(LeftAddress), lpBuffer, nSize, lpNumberOfBytes);
      VirtualProtectEx(ProcessHandle,Pointer(LeftAddress), nSize, mbi_thunk.Protect,dwOldProtect);
      
    //---------------写right
      lpBuffer :
    = PChar(GB2Big5(ServerName));   //要写的内容
      nSize:
    = 8;                                //数据长度
      
    //写RightAddress1数据
      VirtualQueryEx(ProcessHandle,Pointer(RightAddress1),mbi_thunk, sizeof(TMemoryBasicInformation));
      VirtualProtectEx(ProcessHandle,Pointer(RightAddress1),nSize,PAGE_EXECUTE_READWRITE,mbi_thunk.Protect);
      WriteProcessMemory(ProcessHandle, Pointer(RightAddress1), lpBuffer, nSize, lpNumberOfBytes);
      VirtualProtectEx(ProcessHandle,Pointer(RightAddress1), nSize, mbi_thunk.Protect,dwOldProtect);
      
    //写RightAddress2数据
      VirtualQueryEx(ProcessHandle,Pointer(RightAddress2),mbi_thunk, sizeof(TMemoryBasicInformation));
      VirtualProtectEx(ProcessHandle,Pointer(RightAddress2),nSize,PAGE_EXECUTE_READWRITE,mbi_thunk.Protect);
      WriteProcessMemory(ProcessHandle, Pointer(RightAddress2), lpBuffer, nSize, lpNumberOfBytes);
      VirtualProtectEx(ProcessHandle,Pointer(RightAddress2), nSize, mbi_thunk.Protect,dwOldProtect);
      
    //读内容,确定是否修改成功
      lpBuffer :
    = AllocMem(nSize);
      ReadProcessMemory(ProcessHandle, Pointer(RightAddress2), lpBuffer, nSize, lpNumberOfBytes);
      
    if ServerName = Big52GB(lpBuffer) then begin
        Caption :
    = '内存内容为:' + Big52GB(lpBuffer);
        tmrChangeServerName.Enabled :
    = False;
      
    end;
      CloseHandle(ProcessHandle);  
    //   Memo1.Lines.Add(Big52GB(lpBuffer));
      
    //MEMO显示信息  
    //  Memo1.Lines.Clear;
    //  memo1.lines.add('Process ID ' + IntToHex(FProcessEntry32.th32ProcessID, 8));
    //  memo1.lines.Add('File name ' + FProcessEntry32.szExeFile);
    //  memo1.Lines.Add('Process Handle ' + intTohex(ProcessHandle, 8));
    //  Memo1.Lines.Add('虚拟内存中的数据:');
    end;
  • 相关阅读:
    EFCore.BulkExtensions Demo
    查询处理器用尽了内部资源,无法生成查询计划。这种情况很少出现,只有在查询极其复杂或引用了大量表或分区时才会出现。请简化查询。如果您认为该消息的出现纯属错误,请与客户支持服务部门联系,了解详细信息
    .net core 删除主表,同时删除子表
    java 数据类型优先级
    string.Join 的用法
    JDK-13下载安装及环境变量配置
    Java 前加加和后加加 总结
    变量类型查看-type
    路径:获取 & 更改
    用sql获取数据库中所有的表名、字段名
  • 原文地址:https://www.cnblogs.com/jxgxy/p/1520444.html
Copyright © 2011-2022 走看看