mirror of
https://silica.codes/BedrockReverse/MCEELoginSkip.git
synced 2025-04-06 21:25:49 +12:00
v1.3
This commit is contained in:
parent
928dde5ba0
commit
a384b2c17a
1 changed files with 64 additions and 27 deletions
|
@ -3,6 +3,8 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <psapi.h>
|
#include <psapi.h>
|
||||||
|
#include <wchar.h>
|
||||||
|
#include <string.h>
|
||||||
#include <TlHelp32.h>
|
#include <TlHelp32.h>
|
||||||
|
|
||||||
int* pointer_path;
|
int* pointer_path;
|
||||||
|
@ -48,9 +50,30 @@ uintptr_t GetProcessBaseAddress(HANDLE process) // from stackoverflow
|
||||||
return baseAddress;
|
return baseAddress;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DWORD GetProcId(WCHAR* name)
|
||||||
|
{
|
||||||
|
PROCESSENTRY32 entry;
|
||||||
|
entry.dwSize = sizeof(PROCESSENTRY32);
|
||||||
|
|
||||||
|
HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, NULL);
|
||||||
|
|
||||||
|
if (Process32First(snapshot, &entry) == TRUE)
|
||||||
|
{
|
||||||
|
while (Process32Next(snapshot, &entry) == TRUE)
|
||||||
|
{
|
||||||
|
if (wcscmp(entry.szExeFile, name) == 0)
|
||||||
|
{
|
||||||
|
return entry.th32ProcessID;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CloseHandle(snapshot);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char* argv[])
|
int main(int argc, char* argv[])
|
||||||
{
|
{
|
||||||
HWND hWnd = NULL;
|
|
||||||
FILE* ptr_file;
|
FILE* ptr_file;
|
||||||
char MEE_POINTER_FILE[0x2048];
|
char MEE_POINTER_FILE[0x2048];
|
||||||
int LOGIN_STEP_VALUE = -1;
|
int LOGIN_STEP_VALUE = -1;
|
||||||
|
@ -140,12 +163,12 @@ int main(int argc, char* argv[])
|
||||||
num_ptr = 8;
|
num_ptr = 8;
|
||||||
pointer_path = (int*)malloc(num_ptr * sizeof(int));
|
pointer_path = (int*)malloc(num_ptr * sizeof(int));
|
||||||
|
|
||||||
pointer_path[0] = 0x2594A58;
|
pointer_path[0] = 0x2CFFF40;
|
||||||
pointer_path[1] = 0x60;
|
pointer_path[1] = 0x30;
|
||||||
pointer_path[2] = 0x138;
|
pointer_path[2] = 0x8;
|
||||||
pointer_path[3] = 0x58;
|
pointer_path[3] = 0x20;
|
||||||
pointer_path[4] = 0x480;
|
pointer_path[4] = 0x570;
|
||||||
pointer_path[5] = 0x10;
|
pointer_path[5] = 0x18;
|
||||||
pointer_path[6] = 0xA8;
|
pointer_path[6] = 0xA8;
|
||||||
pointer_path[7] = 0x0;
|
pointer_path[7] = 0x0;
|
||||||
}
|
}
|
||||||
|
@ -162,21 +185,19 @@ int main(int argc, char* argv[])
|
||||||
printf_s("\n");
|
printf_s("\n");
|
||||||
|
|
||||||
// Hack the universe.
|
// Hack the universe.
|
||||||
|
DWORD proc_id = NULL;
|
||||||
|
|
||||||
printf_s("\n\nPlease open Minecraft Education Edition\n");
|
printf_s("\nPlease open Minecraft Education Edition\n");
|
||||||
while (hWnd == NULL)
|
while (proc_id == NULL)
|
||||||
{
|
{
|
||||||
hWnd = FindWindow(0, L"Minecraft: Education Edition");
|
proc_id = GetProcId(L"Minecraft.Windows.exe");
|
||||||
|
if (proc_id == NULL)
|
||||||
|
proc_id = GetProcId(L"Minecraft.Win10.DX11.exe");
|
||||||
}
|
}
|
||||||
printf_s("MCEE Window Handle: %x\n", hWnd);
|
|
||||||
DWORD proc_id;
|
|
||||||
GetWindowThreadProcessId(hWnd, &proc_id);
|
|
||||||
printf_s("MCEE Process ID: %x\n", proc_id);
|
printf_s("MCEE Process ID: %x\n", proc_id);
|
||||||
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, TRUE, proc_id);
|
HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, TRUE, proc_id);
|
||||||
printf_s("MCEE Process Handle: %x\n", hProcess);
|
printf_s("MCEE Process Handle: %x\n", hProcess);
|
||||||
|
|
||||||
uintptr_t baseAddress = (uintptr_t)GetProcessBaseAddress(proc_id);
|
|
||||||
printf_s("MCEE Base Addr: %llx\n", baseAddress);
|
|
||||||
|
|
||||||
if (!hProcess)
|
if (!hProcess)
|
||||||
{
|
{
|
||||||
|
@ -185,22 +206,32 @@ int main(int argc, char* argv[])
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
||||||
|
uintptr_t baseAddress = NULL;
|
||||||
|
while(baseAddress == NULL)
|
||||||
|
baseAddress = (uintptr_t)GetProcessBaseAddress(proc_id);
|
||||||
|
|
||||||
|
printf_s("MCEE Base Addr: %llx\n", baseAddress);
|
||||||
|
|
||||||
|
|
||||||
printf_s("Waiting for game to initalize....\n");
|
printf_s("Waiting for game to initalize....\n");
|
||||||
|
|
||||||
read_ptr_path:
|
read_ptr_path:
|
||||||
|
|
||||||
|
baseAddress = (uintptr_t)GetProcessBaseAddress(proc_id); // recalculate base address idk why but this seems to be required.
|
||||||
|
|
||||||
|
|
||||||
// Read first ptr
|
// Read first ptr
|
||||||
"weird compiler shiz right here..";
|
uintptr_t first_ptr = pointer_path[0];
|
||||||
|
uintptr_t cur_ptr = baseAddress + first_ptr;
|
||||||
uintptr_t cur_ptr = baseAddress + pointer_path[0];
|
|
||||||
uintptr_t ptr = 0;
|
uintptr_t ptr = 0;
|
||||||
uintptr_t new_ptr = 0;
|
uintptr_t new_ptr = 0;
|
||||||
|
|
||||||
|
|
||||||
while (ptr == 0)
|
|
||||||
{
|
ReadProcessMemory(hProcess, cur_ptr, &ptr, sizeof(uintptr_t), 0);
|
||||||
ReadProcessMemory(hProcess, cur_ptr, &ptr, sizeof(uintptr_t), 0);
|
if (ptr == 0)
|
||||||
}
|
goto read_ptr_path;
|
||||||
|
|
||||||
|
|
||||||
for (int i = 1; i < num_ptr-1; i++) // Follow path...
|
for (int i = 1; i < num_ptr-1; i++) // Follow path...
|
||||||
{
|
{
|
||||||
|
@ -234,11 +265,17 @@ int main(int argc, char* argv[])
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf_s("Trying login stage 6...\n"); // Backwards Comp (1.9 and lower)
|
printf_s("Trying login stage 5...\n"); // Backwards Comp (0.xx)
|
||||||
int login_step_value = 6;
|
int login_step_value = 5;
|
||||||
WriteProcessMemory(hProcess, (void*)ptr, &login_step_value, sizeof(int), 0);
|
WriteProcessMemory(hProcess, (void*)ptr, &login_step_value, sizeof(int), 0);
|
||||||
|
|
||||||
Sleep(1 * 500);
|
Sleep(1 * 200);
|
||||||
|
|
||||||
|
printf_s("Trying login stage 6...\n"); // Backwards Comp (1.9 and lower)
|
||||||
|
login_step_value = 6;
|
||||||
|
WriteProcessMemory(hProcess, (void*)ptr, &login_step_value, sizeof(int), 0);
|
||||||
|
|
||||||
|
Sleep(1 * 200);
|
||||||
|
|
||||||
printf_s("Trying login stage 8...\n");
|
printf_s("Trying login stage 8...\n");
|
||||||
login_step_value = 8;
|
login_step_value = 8;
|
||||||
|
|
Loading…
Add table
Reference in a new issue