Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 19.11.2014
Сообщений: 86
1

Память процесса

25.08.2017, 17:41. Показов 3086. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый вечер. Работаю с программой Cheat Engine для поиска статических адресов памяти процесса (копаюсь в памяти эмуляторов ретро-консолей). В общем, в чем проблема:
Имеется один эмулятор, с которым не могу разобраться. Его статические адреса постоянно меняются, а в окне редактирования указателя пишет так: "MesenCore.dll"+04264098. Я так понимаю из-за этого постоянно, и меняются адреса?
Как средствами C# узнать это самое значение "MesenCore.dll"? Уточню, что эмулятор 64-разрядный, а моя софтинка 32-разрядная.
Миниатюры
Память процесса  
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
25.08.2017, 17:41
Ответы с готовыми решениями:

Память процесса
Доброго времени суток. Пишу античит и столкнулся с проблемой, как защитить память процесса (не...

Виртуальная память процесса
Доброго времени суток. Задача следущая: есть необходимость заглянуть в виртуальную память...

Завершение процесса при обнаружении другого процесса
Здравствуйте. Люди добрые подскажите пожалуйста как мне быть. Есть приложение которое следит за...

Получить ID процесса если известно его хэндл, название окна или название процесса
а как получить ID процесса если известно его хэндл, название окна или название процесса?

5
0 / 0 / 0
Регистрация: 19.11.2014
Сообщений: 86
25.08.2017, 21:35  [ТС] 2
Как же достать модули 64бит процесса из 32битного приложения?
0
138 / 138 / 53
Регистрация: 14.06.2016
Сообщений: 467
25.08.2017, 23:36 3
например из 64битного пеба
1
0 / 0 / 0
Регистрация: 19.11.2014
Сообщений: 86
26.08.2017, 07:16  [ТС] 4
можно подробнее? я никогда с этим не сталкивался
0
138 / 138 / 53
Регистрация: 14.06.2016
Сообщений: 467
26.08.2017, 14:38 5
Лучший ответ Сообщение было отмечено DiZ911 как решение

Решение

что то около
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
using System;
using System.Linq;
using System.Runtime.InteropServices;
using System.Diagnostics;
 
namespace ConsoleApp1 {
    class Program {
 
        [DllImport("ntdll.dll")]
        static unsafe extern uint NtWow64QueryInformationProcess64(IntPtr handle, int infoClass, void* info, int infoLength, out int returnLength);
        [DllImport("ntdll.dll")]
        static unsafe extern uint NtWow64ReadVirtualMemory64(IntPtr handle, long baseAddress, void* buffer, long size, out long readed);
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        struct PROCESS_BASIC_INFORMATION64 {
            public uint ExitStatus;
            public uint Reserved0;
            public long PebBaseAddress;
            public long AffinityMask;
            public int BasePriority;
            public uint Reserved1;
            public long UniqueProcessId;
            public long InheritedFromUniqueProcessId;
        }
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        struct LIST_ENTRY64 {
            public long Flink;
            public long Blink;
        }
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        unsafe struct PEB64 {
            fixed byte pad[24];
            public long Ldr;
        }
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        unsafe struct LDR_DATA64 {
            fixed byte pad[16];
            public LIST_ENTRY64 InLoadOrderModuleList;
        }
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        struct UNICODE_STRING64 {
            public short Length;
            public short MaximumLength;
            public long Buffer;
        }
 
        [StructLayout(LayoutKind.Sequential, Pack = 8)]
        struct LDR_DATA_TABLE_ENTRY_BASE_64 {
            public LIST_ENTRY64 InLoadOrderLinks;
            public LIST_ENTRY64 InMemoryOrderLinks;
            public LIST_ENTRY64 InInitializationOrderLinks;
            public long DllBase;
            public long EntryPoint;
            public int SizeOfImage;
            public UNICODE_STRING64 FullDllName;
            public UNICODE_STRING64 BaseDllName;
        }
 
        static unsafe void Main(string[] args) {
            var pbi = new PROCESS_BASIC_INFORMATION64();
            var peb = new PEB64();
            
            var proc = Process.GetProcessesByName("taskmgr").First();
            var status = NtWow64QueryInformationProcess64(proc.Handle, 0, &pbi, sizeof(PROCESS_BASIC_INFORMATION64), out int ret);
            
            var readed = 0L;
            status = NtWow64ReadVirtualMemory64(proc.Handle, pbi.PebBaseAddress, &peb, sizeof(PEB64), out readed);
 
            var firstEntry = new LIST_ENTRY64();
            var pFirstEntry = peb.Ldr + 16;
            status = NtWow64ReadVirtualMemory64(proc.Handle, pFirstEntry, &firstEntry, sizeof(LIST_ENTRY64), out readed);
 
            for (long pEntry = firstEntry.Flink; pEntry != pFirstEntry; ) {
                var entry = new LIST_ENTRY64();
                status = NtWow64ReadVirtualMemory64(proc.Handle, pEntry, &entry, sizeof(LIST_ENTRY64), out readed);
                if (status != 0) {
                    break;
                }
 
                var imageEntry = new LDR_DATA_TABLE_ENTRY_BASE_64();
                status = NtWow64ReadVirtualMemory64(proc.Handle, pEntry, &imageEntry, sizeof(LDR_DATA_TABLE_ENTRY_BASE_64), out readed);
                if (status != 0) {
                    break;
                }
 
                var buffer = new char[imageEntry.BaseDllName.Length / 2];
                fixed (char* pBuffer = buffer)
                    status = NtWow64ReadVirtualMemory64(proc.Handle, imageEntry.BaseDllName.Buffer, pBuffer, buffer.Length * 2, out readed);
 
                var dllName = new string(buffer);
                Console.WriteLine($"name {dllName} base {imageEntry.DllBase:X} size {imageEntry.SizeOfImage:X} ");
 
                pEntry = entry.Flink;
            }
 
            Console.ReadKey();
        }
    }
}
0
0 / 0 / 0
Регистрация: 19.11.2014
Сообщений: 86
26.08.2017, 15:25  [ТС] 6
Спасибо, после работы буду пробовать
0
26.08.2017, 15:25
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
26.08.2017, 15:25
Помогаю со студенческими работами здесь

Запуск процесса процесса, приложения на стороне клиента
Доброго времени суток господа программисты, помогите новичку решить вопрос, Есть Web приложение...

Прочитать память процесса
Здравствуйте, незнаю как назвать тему, вообщем есть программа hex editor, как средствами C# так же...

Прочитать память процесса
Задача такая: есть игра, я знаю адрес нужного мне значения(хп), мне нужно чтобы когда это значение...

Как сверить имя процесса и путь основного процесса?
Подскажите как мне сверить путь с именем процесса svchost.exe если файл запущен из папки System32...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru