|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
||||||
Запуск .NET C# программы из памяти C++ приложения13.07.2017, 00:24. Показов 5788. Ответов 31
Понадобилось реализовать запуск .NET C# программы прямо из памяти C++ приложения.
Использую функцию:
Ну и сам вопрос: возможно ли это устранить или с .NET C# приложениями такой вид запуска не прокатит? P.S. Долго думал, в какой раздел написать, если всё-таки перепутал - модераторы, перекиньте тему в правильный раздел
0
|
||||||
| 13.07.2017, 00:24 | |
|
Ответы с готовыми решениями:
31
выдает ошибку памяти. Запуск программы в юникс Запуск программы или файла с консольного приложения |
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 14.07.2017, 00:49 [ТС] | |
|
Ещё актуально. Подскажите хоть что-то :-(
0
|
|
|
Ушел с форума
|
|
| 14.07.2017, 08:50 | |
|
.NET-приложения должны содержать, как минимум, секцию "CLR Runtime Header".
По наличию этой секции загрузчик из ntdll.dll инициализирует и проверяет нужные структуры, а затем устанавливает правильную точку входа в CONTEXT. А она, кстати, там равна не OptionalHeader.AddressOfEntryPoint, а _CorExeMain из mscoree.dll.
1
|
|
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|||||||
| 14.07.2017, 13:26 [ТС] | |||||||
0
|
|||||||
|
Ушел с форума
|
|
| 14.07.2017, 13:44 | |
Сообщение было отмечено edward_freedom как решение
Решение
И не должно
![]() Как работает запуск процесса? Ты вызываешь функцию CreateProcessXxx, выполняется проверка аргументов, подготовка всяких структур данных, переменные окружения и т.д. Далее выполняется прыжок в ядро. Ядро создает системные объекты EPROCESS (процесс), ETHREAD (первичный поток), создает адресное пространство для процесса, в нем структуры PEB, TEB и другие, и далее выполняется прыжок обратно в режим пользователя (через механизм APC) на функцию ntdll!LdrInitializeThunk. С этого момента начинается пользовательская часть инициализации процесса: загрузка связанных dll, инициализация TLS-калбэков и т.д. Вот теперь важный момент: если загрузчик видит, что в exe есть секция "CLR Runtime Header" (индекс 14 в PE data directories, если не ошибаюсь), то он сам меняет в CONTEXT точку входа на mscoree!_CorExeMain. Ну а _CorExeMain - это и есть инициализация процесса .NET. Без секции "CLR Runtime Header" точно ничего работать не будет. Подробнее узнать, как запускается процесс, можно в следующих источниках: 1. "Windows Internals" М. Руссиновича. Он там все очень подробно описывает, страниц на 20, наверное. 2. Исходники NT4/W2K/WRK. См. функции LdrInitialize и далее. 3. Дизассемблирование ntdll современных версий Windows.
3
|
|
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|||||
| 14.07.2017, 14:00 [ТС] | |||||
![]()
0
|
|||||
|
Ушел с форума
|
|||
| 14.07.2017, 16:20 | |||
|
какую сторону копать и где искать ответы.
0
|
|||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 14.07.2017, 17:10 [ТС] | |
|
0
|
|
|
Ушел с форума
|
||
| 14.07.2017, 17:12 | ||
|
Все исходники не обязательно, достаточно найти нужные фрагменты:
Процесс-то все равно привязывается к файлу на диске (который у тебя в аргументе szFilePath функции ExecFile)...
0
|
||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|||
| 15.07.2017, 00:01 [ТС] | |||
|
Добавлено через 6 часов 35 минут Почитал про ![]() При запуске надо выполнить всё за неё или, наоборот, её (как-то) вызвать?
0
|
|||
|
232 / 135 / 19
Регистрация: 10.11.2015
Сообщений: 305
|
||
| 16.07.2017, 19:43 | ||
|
0
|
||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 16.07.2017, 19:48 [ТС] | |
|
jupman, т.е. мне надо при запуске вызывать _CorExeMain?
0
|
|
|
232 / 135 / 19
Регистрация: 10.11.2015
Сообщений: 305
|
||
| 16.07.2017, 20:26 | ||
|
Добавлено через 14 минут Mikha Mikhin, Изменение PE-заголовка в процессе выполнения программы
0
|
||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
||
| 16.07.2017, 20:54 [ТС] | ||
|
0
|
||
|
232 / 135 / 19
Регистрация: 10.11.2015
Сообщений: 305
|
|||||
| 16.07.2017, 21:02 | |||||
|
Добавлено через 4 минуты
0
|
|||||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 16.07.2017, 21:11 [ТС] | |
|
jupman, т.е. запуск у меня нормальный, но помимо его мне надо будет хукать ZwMapViewOfSection?
0
|
|
|
232 / 135 / 19
Регистрация: 10.11.2015
Сообщений: 305
|
|
| 16.07.2017, 21:30 | |
|
Mikha Mikhin, таким способом как у тебя реализовать загрузку .NET сложнее. Лучше грузи без инжектов:
1) Собираешь образ в памяти 2) Если требуется обрабатываешь релоки 3) Обрабатываешь таблицу импорта 4) Патчиш PEB.ImageBaseAddress и поля EntryPoint, DllBase, SizeOfImage из LDR_DATA_TABLE_ENTRY 5) Патчиш LDR_DATA_TABLE_ENTRY.Flags на LDRP_COR_IMAGE 6) Ставиш хук на ZwMapViewOfSection (подсовывание оригинального образа) 7) Вызываешь _CorExeMain
0
|
|
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 16.07.2017, 21:40 [ТС] | |
|
jupman, как я понимаю, хук надо будет ставить на уровне драйвера?
0
|
|
|
232 / 135 / 19
Регистрация: 10.11.2015
Сообщений: 305
|
|||
| 16.07.2017, 21:46 | |||
|
Добавлено через 2 минуты
0
|
|||
|
3 / 3 / 2
Регистрация: 06.12.2016
Сообщений: 176
|
|
| 16.07.2017, 22:11 [ТС] | |
|
0
|
|
| 16.07.2017, 22:11 | |
|
Помогаю со студенческими работами здесь
20
Запуск не .Net приложения в памяти
Запуск приложения без .Net Сканирование оперативной памяти запуск приложения Запуск приложения на всех версиях .Net Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|