Jump to content

Game Hacking with Python and cheat engine


Recommended Posts

  • Administrator

spacer.png

Now what we need to do next is go back to the pointer scan window, click on pointer scan, then rescan memory.

Paste the new address and click OK.

spacer.png

Now we have 14958. It is less than our previous scan. You can either repeat the proccess again and try to get the pointer paths lower or you can proceed to the next part. I will not scan anymore for this example

Now for the next step, we have to guess. Which of these address do actually point to the address.

So we will double click random pointers. Just a note, ignore the threadstacks. I picked 4 values

spacer.png

 

Now we will test if these pointers do actually point to the health. We can do that by restarting the game again.

spacer.png

After restarting the game, we can see that their values still match our in game health so that must mean they all actually points to the health address. Now you can pick any of those addresses but i will pick the first one. We can further confirm that this is pointer point to the health by modifying its value

spacer.png

Now we are 100% sure that this pointer point to the health address in the game. If we double click it, we can see that it is a multilevel pointer

This is the hidden content, please
/applications/core/interface/js/spacer.png">

Python Scripting

Now in this part, we will be accessing this pointer and we will access the memory address it points to and modify it using python. We will be using pymeow for this writeup since from all the libraries i tested, this is the only one that worked. You can download pymeow here https://github.com/qb-0/PyMeow

So we will make a new script and we will start by importing the library

After that, we can start coding. We will follow the cheatsheet of pymeow for https://github.com/qb-0/PyMeow/blob/master/cheatsheet.txt

There is 2 way to get the process, process_by_name, and process_by_pid. We will be using process_by_name since it is easier.

spacer.png

In there we passed the name of the program ULTRAKILL.exe.

Now, we have to get the base address of the pointer.

  • Thanks 1
  • Administrator

spacer.png

In our case, the base address is “mono-2.0-bdwgc.dll”+004A1820. So, first, we have to get the address of mono-2.0-bdwgc.dll and add 0x004A1820 to it to get the base address. In pymeow, Process objects have a dictionary called modules that contains all the modules and those modules are also dictionaries and they have a parameter called baseaddr.

 

spacer.png

Now what we want to do is get the base address of mono-2.0-bdwgc.dll and we can access it with process[“modules”][“mono-2.0-bdwgc.dll”][“baseaddr”], then we will add 0x017C58C0 to it to get the base address of the pointer.

This is the hidden content, please
/applications/core/interface/js/spacer.png">

We can confirm that this is the right address in cheat engine

spacer.png

 

Now we have to deal with offsets. First, i will explain how offsets works and how we will deal with them.

spacer.png

Here, we can see that it has 7 offsets. We can see that below, the first address is 0x7ff920af1820. Then, the first offset came which is 140. What it does is it adds 0x140 bytes to the first address which is 0x7ff920af1820 and then it will get the value in that address with offset. Now that address points to another pointer and again, we will add 0x1F0 bytes into that pointer until we get to the last part which is the actual memory address of the user health. Now, lets implement it in our code.

pymeow has a method pointer_chain but its not working for me so we will implement our own function instead.

1*Zu9Xhv6I5LyasNQKT_eVRQ.png

I came up with a function that i called read_offsets. It takes 3 arguments, the first one is the proc, which is the process, the second is the base address, the third is the array of offsets. In line 4, it will get the pointer in the base address. In line 6, it makes a new variable called current_pointer from the basepoint variable. Then it will loop through every offsets except for the last character, what it does is, it will read the pointer in the current_pointer+offset and set the value of current_pointer to it for the next iteration. Then in the last part, it will return the final pointer.

We use read_int64 since we are working on a 64 bit program and memory address in 64 bit programs are 8 bytes. Now lets try it if it works

 

This is the hidden content, please
/applications/core/interface/js/spacer.png">

I mapped out the offsets into an array in my code. Now lets run it.

1*iv3P0RXP3NTplFPidT71PQ.png

We can see that it works, it obtained the value 1337 which is the value we set the health earlier in in cheat engine.

Now lets try modifying that address using write_int.

This is the hidden content, please
/applications/core/interface/js/spacer.png">

Now if we get back to the game,

1*NhSzdhLWg1b8j3XF2eNHuA.png

We can see that it is successful and our health is now 200.

This is the end of my writeup. I hope this resource will help for future hackers that are interested on game hacking with python. Thanks for reading

Credits: Brandon Roldan

  • Thanks 1

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...