Драйвер для вывода сообщения об открытии .txt файла [closed]C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Драйвер для вывода сообщения об открытии .txt файла [closed]

Сообщение Anonymous »

пишу WDM драйвер для сдачи задания. Драйвер должен выводить в DbgView сообщение "текстовой файл открыт", но вместо это выводится сообщение только о том, что драйвер загружен. Помогите пожалуйста подправить код или объясните что я делаю не так. Использую виртуальную машину VMware, тестирую на Windows 10 Pro, так как для драйверов требуется "Подпись", то включаю тестовый режим. Спасибо.
Код файла TestDriverWindows.cpp
#include "FileOpenLogger.h"

VOID DriverUnload(PDRIVER_OBJECT DriverObject)
{
UNREFERENCED_PARAMETER(DriverObject);
DbgPrint("Driver Unloading\n");
}

NTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath) {
UNREFERENCED_PARAMETER(DriverObject);
UNREFERENCED_PARAMETER(RegistryPath); // Указываем, что параметр не используется

DbgPrint("Driver Loaded\n"); // Сообщение о подключении драйвера

DriverObject->DriverUnload = DriverUnload;

DbgPrint("Driver 123\n");

// Установите обработчик для IRP_MJ_CREATE
DriverObject->MajorFunction[IRP_MJ_CREATE] = [](PDEVICE_OBJECT DeviceObject, PIRP Irp) -> NTSTATUS
{
UNREFERENCED_PARAMETER(DeviceObject); // Указываем, что параметр не используется
DbgPrint("IRP_MJ_CREATE called\n");
// Получаем указатель на FILE_OBJECT из IRP
PIO_STACK_LOCATION irpSp = IoGetCurrentIrpStackLocation(Irp);
PFILE_OBJECT fileObject = irpSp->FileObject;

// Проверяем имя файла
if (fileObject->FileName.Length > 0) {
UNICODE_STRING fileName = fileObject->FileName;
if (fileName.Buffer[fileName.Length / sizeof(WCHAR) - 1] == L't' &&
fileName.Buffer[fileName.Length / sizeof(WCHAR) - 2] == L'x' &&
fileName.Buffer[fileName.Length / sizeof(WCHAR) - 3] == L't' &&
fileName.Buffer[fileName.Length / sizeof(WCHAR) - 4] == L'.') {
// Логируем только текстовые файлы
DbgPrint("Text file opened: %wZ\n", fileName);
}
}

// Завершение IRP
Irp->IoStatus.Status = STATUS_SUCCESS;
Irp->IoStatus.Information = 0;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
return STATUS_SUCCESS;
};

DbgPrint("Driver exit\n");

return STATUS_SUCCESS;
}

Код файла FileOpenLogger.h
#pragma once

#include

extern "C" NTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath);
extern "C" VOID DriverUnload(PDRIVER_OBJECT DriverObject);



Подробнее здесь: https://stackoverflow.com/questions/796 ... 0%bb%d0%b0
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»