Função NetSessionGetInfo (lmshare.h)
Recupera informações sobre uma sessão estabelecida entre um servidor específico e uma estação de trabalho.
Sintaxe
NET_API_STATUS NET_API_FUNCTION NetSessionGetInfo(
[in] LMSTR servername,
[in] LMSTR UncClientName,
[in] LMSTR username,
[in] DWORD level,
[out] LPBYTE *bufptr
);
Parâmetros
[in] servername
Ponteiro para uma cadeia de caracteres que especifica o nome DNS ou NetBIOS do servidor remoto no qual a função deve ser executada. Se esse parâmetro for NULL, o computador local será usado.
[in] UncClientName
Ponteiro para uma cadeia de caracteres que especifica o nome da sessão do computador para a qual as informações devem ser retornadas. Esse parâmetro é necessário e não pode ser NULL. Para obter mais informações, consulte NetSessionEnum.
[in] username
Ponteiro para uma cadeia de caracteres que especifica o nome do usuário cujas informações de sessão devem ser retornadas. Esse parâmetro é necessário e não pode ser NULL.
[in] level
Especifica o nível de informações dos dados. Esse parâmetro pode usar um dos valores a seguir.
Valor | Significado |
---|---|
|
Retornar o nome do computador que estabeleceu a sessão.
O parâmetro bufptr aponta para uma estrutura SESSION_INFO_0 . |
|
Retornar o nome do computador, o nome do usuário e abrir arquivos, pipes e dispositivos no computador.
O parâmetro bufptr aponta para uma estrutura SESSION_INFO_1 . |
|
Além das informações indicadas para o nível 1, retorne o tipo de cliente e como o usuário estabeleceu a sessão.
O parâmetro bufptr aponta para uma estrutura SESSION_INFO_2 . |
|
Retornar o nome do computador; nome do usuário; e tempos ativos e ociosos para a sessão.
O parâmetro bufptr aponta para uma estrutura SESSION_INFO_10 . |
[out] bufptr
Ponteiro para o buffer que recebe os dados. O formato desses dados depende do valor do parâmetro level . Para obter mais informações, consulte Buffers de função de gerenciamento de rede e Comprimentos de buffer de função de gerenciamento de rede.
Esse buffer é alocado pelo sistema e deve ser liberado usando a função NetApiBufferFree .
Valor retornado
Se a função for bem-sucedida, o valor retornado será NERR_Success.
Se a função falhar, o valor retornado poderá ser um dos códigos de erro a seguir.
Código de retorno | Descrição |
---|---|
|
O usuário não tem acesso às informações solicitadas. |
|
O valor especificado para o parâmetro de nível não é válido. |
|
O parâmetro especificado não é válido. |
|
Memória insuficiente disponível. |
|
Uma sessão não existe com o nome do computador. |
|
O nome do computador não é válido. |
|
Não foi possível encontrar o nome de usuário. |
Comentários
Somente membros do grupo local Administradores ou Operadores de Servidor podem executar com êxito a função NetSessionGetInfo no nível 1 ou nível 2. Nenhuma associação de grupo especial é necessária para chamadas de nível 0 ou nível 10.
Se você estiver programando para o Active Directory, poderá chamar determinados métodos ADSI (Active Directory Service Interface) para obter a mesma funcionalidade que você pode obter chamando as funções de sessão de gerenciamento de rede. Para obter mais informações, consulte IADsSession e IADsFileServiceOperations.
Se você chamar essa função no nível de informações 1 ou 2 em um servidor membro ou estação de trabalho, todos os usuários autenticados poderão exibir as informações.
Exemplos
O exemplo de código a seguir demonstra como recuperar informações sobre uma sessão usando uma chamada para a função NetSessionGetInfo . O exemplo chama NetSessionGetInfo, especificando o nível de informações 10 ( SESSION_INFO_10). Se a chamada for bem-sucedida, o código imprimirá informações sobre a sessão. Por fim, o exemplo libera a memória alocada para o buffer de informações.
#ifndef UNICODE
#define UNICODE
#endif
#pragma comment(lib, "Netapi32.lib")
#include <stdio.h>
#include <windows.h>
#include <lm.h>
int wmain(int argc, wchar_t *argv[])
{
DWORD dwLevel = 10;
LPSESSION_INFO_10 pBuf = NULL;
LPTSTR pszServerName = NULL;
LPTSTR pszUNCClientName = NULL;
LPTSTR pszUserName = NULL;
NET_API_STATUS nStatus;
//
// Check command line arguments.
//
if (argc == 3)
{
pszUNCClientName = argv[1];
pszUserName = argv[2];
}
else if (argc == 4)
{
pszServerName = argv[1];
pszUNCClientName = argv[2];
pszUserName = argv[3];
}
else
{
wprintf(L"Usage: %s [\\\\ServerName] \\\\ClientName UserName\n", argv[0]);
exit(1);
}
//
// Call the NetSessionGetInfo function, specifying level 10.
//
nStatus = NetSessionGetInfo(pszServerName,
pszUNCClientName,
pszUserName,
dwLevel,
(LPBYTE *)&pBuf);
//
// If the call succeeds,
//
if (nStatus == NERR_Success)
{
if (pBuf != NULL)
{
//
// Print the session information.
//
wprintf(L"\n\tClient: %s\n", pBuf->sesi10_cname);
wprintf(L"\tUser: %s\n", pBuf->sesi10_username);
printf("\tActive: %d\n", pBuf->sesi10_time);
printf("\tIdle: %d\n", pBuf->sesi10_idle_time);
}
}
//
// Otherwise, indicate a system error.
//
else
fprintf(stderr, "A system error has occurred: %d\n", nStatus);
//
// Free the allocated memory.
//
if (pBuf != NULL)
NetApiBufferFree(pBuf);
return 0;
}
Requisitos
Cliente mínimo com suporte | Windows XP [somente aplicativos da área de trabalho] |
Servidor mínimo com suporte | Windows Server 2003 [somente aplicativos da área de trabalho] |
Plataforma de Destino | Windows |
Cabeçalho | lmshare.h (inclua Lm.h) |
Biblioteca | Netapi32.lib |
DLL | Netapi32.dll |
Confira também
Funções de gerenciamento de rede