На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
Обратите внимание:
1. Прежде чем начать новую тему или отправить сообщение, убедитесь, что вы не нарушаете правил форума!
2. Обязательно воспользуйтесь поиском. Возможно, Ваш вопрос уже обсуждали. Полезные ссылки приведены ниже.
3. Темы с просьбой выполнить какую-либо работу за автора в этом разделе не обсуждаются.
4. Используйте теги [ code=cpp ] ...текст программы... [ /code ] для выделения текста программы подсветкой.
5. Помните, здесь телепатов нет. Старайтесь формулировать свой вопрос максимально грамотно и чётко: Как правильно задавать вопросы
6. Запрещено отвечать в темы месячной и более давности без веских на то причин.

Полезные ссылки:
user posted image FAQ Сайта (C++) user posted image FAQ Форума user posted image Наши Исходники user posted image Поиск по Разделу user posted image MSDN Library Online (Windows Driver Kit) user posted image Google

Ваше мнение о модераторах: user posted image B.V.
Модераторы: B.V.
  
> WFP путь к бинарнику фильтра
    Перебираю установленные фильтры посредством вызова FwpmFilterEnum0(), соответственно имею на каждый фильтр структуру FWPM_FILTER0. И всё бы хорошо, но хотелось бы ещё получить путь к драйверу конкретного фильтра.
      Для получения пути к драйверу, связанному с фильтром, можно использовать функцию FwpmFilterGetById0() для получения структуры FWPM_FILTER0 по идентификатору фильтра. Затем можно использовать поле providerKey в полученной структуре для получения информации о драйвере.

      Ниже приведен пример на C++, который демонстрирует использование функций FwpmFilterEnum0() и FwpmFilterGetById0() для перечисления фильтров и получения пути к драйверу для конкретного фильтра:

      ExpandedWrap disabled
        #include <Windows.h>
        #include <fwpmu.h>
        #include <iostream>
         
        #pragma comment(lib, "Fwpuclnt.lib")
         
        int main()
        {
            DWORD numFilters = 0;
            FWPM_FILTER0* filters = nullptr;
            FWPM_FILTER_ENUM_TEMPLATE0 enumTemplate = {};
         
            // Инициализация структуры enumTemplate
            enumTemplate.providerKey = FWPM_GENERAL_CONTEXT_PROVIDER;
            enumTemplate.layerKey = FWPM_LAYER_ALE_AUTH_CONNECT_V4;
         
            // Получение списка фильтров
            DWORD result = FwpmFilterEnum0(
                nullptr,        // дескриптор сессии, если NULL, будет создан автоматически
                &enumTemplate,  // шаблон перечисления
                nullptr,        // начальный индекс
                &filters,       // указатель на массив фильтров
                &numFilters     // количество фильтров в массиве
            );
         
            if (result != ERROR_SUCCESS)
            {
                std::cerr << "Failed to enumerate filters. Error: " << result << std::endl;
                return 1;
            }
         
            for (DWORD i = 0; i < numFilters; i++)
            {
                FWPM_FILTER0& filter = filters[i];
                GUID filterId = filter.filterId;
         
                // Получение дополнительной информации о фильтре по его идентификатору
                FWPM_FILTER0* filterInfo = nullptr;
                result = FwpmFilterGetById0(
                    nullptr,        // дескриптор сессии, если NULL, будет создан автоматически
                    &filterId,      // идентификатор фильтра
                    &filterInfo     // указатель на структуру с информацией о фильтре
                );
         
                if (result != ERROR_SUCCESS)
                {
                    std::cerr << "Failed to get filter info. Error: " << result << std::endl;
                    continue;
                }
         
                // Получение пути к драйверу из поля providerKey в структуре FWPM_FILTER0
                wchar_t* driverPath = filterInfo->providerKey;
         
                std::wcout << "Filter path: " << driverPath << std::endl;
         
                // Освобождение памяти, выделенной для информации о фильтре
                FwpmFreeMemory0(reinterpret_cast<void**>(&filterInfo));
            }
         
            // Освобождение памяти, выделенной для списка фильтров
            FwpmFreeMemory0(reinterpret_cast<void**>(&filters));
         
            return
      0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
      0 пользователей:


      Рейтинг@Mail.ru
      [ Script execution time: 0,0199 ]   [ 18 queries used ]   [ Generated: 9.12.24, 12:33 GMT ]