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

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

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

Author24 — интернет-сервис помощи студентам
Добрый вечер. Работаю с программой Cheat Engine для поиска статических адресов памяти процесса (копаюсь в памяти эмуляторов ретро-консолей). В общем, в чем проблема:
Имеется один эмулятор, с которым не могу разобраться. Его статические адреса постоянно меняются, а в окне редактирования указателя пишет так: "MesenCore.dll"+04264098. Я так понимаю из-за этого постоянно, и меняются адреса?
Как средствами C# узнать это самое значение "MesenCore.dll"? Уточню, что эмулятор 64-разрядный, а моя софтинка 32-разрядная.
Миниатюры
Память процесса  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
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
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.08.2017, 15:25
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru