169 похожих чатов

Нужна платная консультация по перехвату DeviceIoControl под Win64. Есть программа,

который загружает разные модули (DLL), обращающиеся к драйверу железки через DeviceIoControl.
Обращение к железке из основного процесса выглядит так:
Main Process: LoadLibrary (внешняя DLL)
Внешняя DLL: CreateFile ("\\.\Device")
DeviceIoControl(hDevice, ControlCode, DataBuffer)

Через DLL-hijacking я встраиваю в процесс свою собственную DLL, задача которой перехват обращений к железке. Эмуляция железки через подмену/перехват в драйвере и написанию собственного драйвера железки - не решение задачи, нужен перехват из собственной DLL.
1. Возможно ли подобное решение?
2. Если возможно, то как?

8 ответов

13 просмотров

Платная? Или это я неправильно вопрос прочитал, но за что там платить? Функция DeviceIoControl - одна Перехвати её один раз в kernel32, и перехватишь все вызовы

maplum- Автор вопроса
Entusiast
Платная? Или это я неправильно вопрос прочитал, но...

правильно прочитал. консультацию хочу с примером кода

maplum
правильно прочитал. консультацию хочу с примером к...

Через час напишу. За бесплатно. Тебе же нужно по шаблону хукнуть, или для каждой DLL с каждым вызовом - разный шаблон?

maplum- Автор вопроса
Entusiast
Платная? Или это я неправильно вопрос прочитал, но...

А вызовы из других программ как фильтровать? Есть какое-то время между вызовом CreateFileA (открытием драйвера) и вызовом DeviceIoControl. В этот период может прилететь ещё один CreateFileA

maplum- Автор вопроса
Entusiast
Через час напишу. За бесплатно. Тебе же нужно по ...

DLL-ки, которые к DeviceIoControl - разные, но из под одного процесса вызываются. Моя хукающая DLL в том же процессе вызывается

maplum
DLL-ки, которые к DeviceIoControl - разные, но из ...

может тебе проще таблицу импорта переписать?

maplum- Автор вопроса
disba1ancer
может тебе проще таблицу импорта переписать?

Тогда придётся ещё и LoadLibrary перехватывать и править таблицу импортов, когда другие DLL подгружаются. Утяжеляет конструкцию

Похожие вопросы

Обсуждают сегодня

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Если подытожить: По мнению Розыча и Хемуля и др. - предпочтительно по возможности объявлять в секции имплементации потому-что: 1) Выше скорость компиляции 2) Не замусоривается...
notme
7
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
В дельфе нет никакого коробочного (без установки третьих либ) способа получить CallStack с расшифровкой отладочных символов?
notme
7
Приветики всем!)) Подскажите: есть функция, которая записывает число типа Cardinal в четыре байта, хранимые в TBytes. Можете помочь мне, показав, как должна выглядеть функци...
Моринаро
5
Карта сайта