-1

我正在为游戏编写服务器管理器,但遇到了 C# 中的指针和偏移量。旧的服务器管理器是用 vb6 编写的,由于某种原因在我的 Windows 上不起作用,所以我决定用 C# 编写它的一些基本功能。

我有所有必要的指针和偏移值,现在我写的只是为了获取所有玩家的名字。

玩家指针 = 96C290 玩家姓名偏移量 = +20

+668的偏移量给了我下一个玩家的指针,给下一个玩家加上+20应该给我下一个玩家的名字,依此类推。

读取第一个玩家姓名

  public static IntPtr BASE_ADDR = new IntPtr(0x96C290);
  public static IntPtr OFFSET_NAME = new IntPtr(0x20);
  const int PROCESS_WM_READ = 0x0010;

  public static void Read()
  {

        Process process = Process.GetProcessesByName("gameprocessname")[0];
        IntPtr processHandle = OpenProcess(PROCESS_WM_READ, false, process.Id);   

        //defining data structures
        int bytesRead = 0;
        byte[] buffer = new byte[4];

        //Reading Base Address pointer value
        ReadProcessMemory((int)processHandle,(int)BASE_ADDR, buffer, 4, ref bytesRead);
        IntPtr myBaseAddress = new IntPtr(BitConverter.ToInt32(buffer, 0));

        //Adding offset of 20 to original base pointer address
        IntPtr namePointer = BASE_ADDR;
        namePointer = IntPtr.Add(namePointer,(int)OFFSET_NAME);


        //Getting memory address of name pointer
        ReadProcessMemory((int)processHandle, (int)namePointer,buffer, 4, ref bytesRead);
        IntPtr playerNameAddress = new IntPtr(BitConverter.ToInt32(buffer, 0));


        //reading name from name address . ASCII and Unicode
        byte[] playerNameBuffer = new byte[256];
         ReadProcessMemory((int)processHandle, (int)playerNameAddress, buffer, 256, ref bytesRead);
        string name = Encoding.Default.GetString(playerNameBuffer);
        MessageBox.Show(name);


        }

我没有得到玩家的名字。用VB6编写的脚本是可操作的。我正在使用Win8.1 64 位,游戏是非常旧的 32 位应用程序。

可能是什么问题呢 ?我使用作弊引擎手动查看值,但它也没有显示任何内容。指针和偏移值是正确的。

我使用了不同的偏移值,但没有一个返回正确的值。

问题是**如果我在编码端做错了什么?或者是操作系统 64 位问题。**

4

1 回答 1

0

我没有测试程序(因为我没有/不知道游戏),但我看到你读了 myBaseAddress 然后你不使用它,可能问题出在以下几行

IntPtr namePointer = BASE_ADDR;
namePointer = IntPtr.Add(namePointer,(int)OFFSET_NAME);

那应该是

IntPtr namePointer = myBaseAddress ;
namePointer = IntPtr.Add(namePointer,(int)OFFSET_NAME);
于 2016-01-23T15:34:41.380 回答