Função WSCWriteProviderOrder32 (sporder.h)
A função WSCWriteProviderOrder32 é usada para reordenar os provedores de transporte de 32 bits disponíveis. A ordem dos protocolos determina a prioridade de um protocolo ao ser enumerado ou selecionado para uso.
Sintaxe
int WSCWriteProviderOrder32(
[in] LPDWORD lpwdCatalogEntryId,
[in] DWORD dwNumberOfEntries
);
Parâmetros
[in] lpwdCatalogEntryId
Um ponteiro para uma matriz de elementos CatalogEntryId encontrados na estrutura WSAPROTOCOL_INFO . A ordem dos elementos CatalogEntryId é a nova ordenação de prioridade para os protocolos.
[in] dwNumberOfEntries
O número de elementos na matriz lpwdCatalogEntryId .
Retornar valor
A função retornará ERROR_SUCCESS (zero) se a rotina for bem-sucedida. Caso contrário, ele retornará um código de erro específico.
Código do erro | Significado |
---|---|
Um ou mais argumentos são inválidos, nenhuma ação foi tomada. | |
Ocorreu um erro não recuperável. Esse erro é retornado sob várias condições, incluindo o seguinte: o usuário não tem os privilégios administrativos necessários para gravar no registro winsock ou ocorreu uma falha ao abrir ou gravar uma entrada de catálogo. | |
Memória insuficiente disponível. Esse erro é retornado quando não há memória suficiente para alocar uma nova entrada de catálogo. | |
|
A rotina pode retornar qualquer código de erro do Registro. |
Comentários
A função WSCWriteProviderOrder32 é uma versão estritamente de 32 bits da função WSCWriteProviderOrder . Em um computador de 64 bits, todas as chamadas não são especificamente de 32 bits (por exemplo, todas as funções que não terminam em "32") operam no catálogo nativo de 64 bits. Os processos executados em um computador de 64 bits devem usar as chamadas de função específicas de 32 bits para operar em um catálogo estritamente de 32 bits e preservar a compatibilidade. As definições e a semântica das chamadas específicas de 32 bits são as mesmas que suas contrapartes nativas.
A ordem na qual os provedores de serviços de transporte são instalados inicialmente rege a ordem na qual eles são enumerados por meio de WSCEnumProtocols32 na interface do provedor de serviços ou por meio de WSAEnumProtocols na interface do aplicativo. Mais importante, essa ordem também rege a ordem na qual os protocolos e provedores de serviços são considerados quando um cliente solicita a criação de um soquete com base em sua família de endereços, tipo e identificador de protocolo.
O Windows Sockets 2 inclui um aplicativo chamado Sporder.exe que permite que o catálogo de protocolos instalados seja reordenado interativamente após a instalação dos protocolos. O Windows Sockets 2 também inclui uma DLL auxiliar ,Sporder.dll que exporta essa interface de procedimento para reordenar protocolos. Essa interface pode ser importada vinculando-se a Sporder.lib.
Veja a seguir cenários em que a função WSCWriteProviderOrder32 pode falhar:
- O parâmetro dwNumberOfEntries não é igual ao número de provedores de serviços registrados.
- O lpwdCatalogEntryId contém um identificador de catálogo inválido.
- O lpwdCatalogEntryId não contém todos os identificadores de catálogo válidos exatamente uma vez.
- A rotina não é capaz de acessar o registro por algum motivo (por exemplo, permissões de usuário inadequadas).
- Outro processo (ou thread) está chamando a função no momento.
Em caso de êxito, WSCWriteProviderOrder32 tentará alertar todos os aplicativos interessados que se registraram para notificação da alteração chamando WSAProviderConfigChange.
A função WSCWriteProviderOrder32 só pode ser chamada por um usuário conectado como membro do grupo Administradores. Se WSCWriteProviderOrder32 for chamado por um usuário que não é membro do grupo Administradores, a chamada de função falhará e WSANO_RECOVERY será retornado. Para computadores em execução no Windows Vista ou no Windows Server 2008, essa função também pode falhar devido ao UAC (controle de conta de usuário). Se um aplicativo que contém essa função for executado por um usuário conectado como um membro do grupo Administradores diferente do Administrador interno, essa chamada falhará, a menos que o aplicativo tenha sido marcado no arquivo de manifesto com um requestedExecutionLevel definido como requireAdministrator. Se o aplicativo no Windows Vista ou no Windows Server 2008 não tiver esse arquivo de manifesto, um usuário conectado como membro do grupo Administradores que não seja o Administrador interno deverá executar o aplicativo em um shell aprimorado como administrador interno (administrador RunAs) para que essa função tenha êxito.
Requisitos
Requisito | Valor |
---|---|
Cliente mínimo com suporte | Windows Vista, Windows XP Professional x64 Edition [somente aplicativos da área de trabalho] |
Servidor mínimo com suporte | Windows Server 2008, Windows Server 2003 x64 Edition [somente aplicativos da área de trabalho] |
Plataforma de Destino | Windows |
Cabeçalho | sporder.h |
Biblioteca | Sporder.lib |
DLL | Ws2_32.dll |