15 мая 2023 года "Исходники.РУ" отмечают своё 23-летие!
Поздравляем всех причастных и неравнодушных с этим событием!
И огромное спасибо всем, кто был и остаётся с нами все эти годы!

Главная Форум Журнал Wiki DRKB Discuz!ML Помощь проекту


Как узнать, кто в данный момент присоединен через Сеть к машине в Windows 95/98/Me (пример использования функции NetSessionEnum)

Windows 95/98/Me: Следующий пример демонстрирует, как пролистать текущие сессии на данной машине при помощи функции NetSessionEnum.

Пример распределяет необходимую память для получения 20-ти структур session_info_50. Если размер выделенной памяти недостаточен, то программа предупредит о наличии большего количества подключений. В заключении, программа освобождает распределённую память.

#include <stdio.h>
#include <assert.h>
#include <windows.h> 
#include <svrapi.h>

const short MAX_ENTRIES = 20;

int main(int argc, char FAR * argv[])
{
   char FAR * pszServerName = NULL;
   short nLevel = 50;
   struct session_info_50* pBuf = NULL;
   struct session_info_50* pTmpBuf = NULL;
   short cbBuffer;
   short nEntriesRead = 0;
   short nTotalEntries = 0;
   short nTotalCount = 0;
   int i;
   NET_API_STATUS nStatus;
   //
   // Для локального компьютера ServerName должно быть NULL.
   //
   if (argc > 2)
   {
      printf("Usage: %s [\\\\ServerName]\n", argv[0]);
      exit(1);
   }

   if (argc == 2)
      pszServerName = argv[1];

   cbBuffer = MAX_ENTRIES * sizeof(struct session_info_50);
   //
   // Распределяем память, требуюмую, для получения 20-ти
   //  структур session_info_50.
   //
   pBuf = malloc(cbBuffer);

   if (pBuf == NULL)
      printf("No memory\n");

   // Вызываем функцию NetSessionEnum для получения списка подключений
   //  указывая информационный уровень 50.
   //
   nStatus = NetSessionEnum(pszServerName,
                            nLevel,
                            (char FAR *)pBuf,
                            cbBuffer,
                            &nEntriesRead,
                            &nTotalEntries);
   //
   // получаем результаты в цикле; обрабатываем ошибки.
   //
   if ((nStatus == NERR_Success) || (nStatus == ERROR_MORE_DATA))
   {
      if ((pTmpBuf = pBuf) != NULL)
      {
         for (i = 0; (i < nEntriesRead); i++)
         {
            assert(pTmpBuf != NULL);

            if (pTmpBuf == NULL)
            {
               fprintf(stderr, "An access violation has occurred\n");
               break;
            }
            //
            // Отображаем информацию по каждому соединению.
            //
            printf("\n\tClient: %s\n", pTmpBuf->sesi50_cname);
            printf("\tUser:   %s\n", pTmpBuf->sesi50_username);
            printf("\tActive: %d\n", pTmpBuf->sesi50_time);
            printf("\tIdle:   %d\n", pTmpBuf->sesi50_idle_time);
            printf("\tKey:   %d\n", pTmpBuf->sesi50_key);

            pTmpBuf++;
            nTotalCount++;
         }
      }
   }
   else
      fprintf(stderr, "A system error has occurred: %d\n", nStatus);
   //
   // Отображаем предупреждение, если буфер не достаточен
   //  для хранения всех полученных данных.
   //
   if ((nEntriesRead < nTotalEntries) || (nStatus == ERROR_MORE_DATA))
      fprintf(stderr, "Not all entries have been enumerated\n");
   //
   // Освобождаем выделенную память.
   //
   if (pBuf != NULL)
      free(pBuf);

   fprintf(stderr, "\nTotal of %d entries enumerated\n", nTotalCount);

   return 0;
}