Condividi tramite


struttura PROTOCOL_INFOA (nspapi.h)

La struttura PROTOCOL_INFO contiene informazioni su un protocollo.

Sintassi

typedef struct _PROTOCOL_INFOA {
  DWORD dwServiceFlags;
  INT   iAddressFamily;
  INT   iMaxSockAddr;
  INT   iMinSockAddr;
  INT   iSocketType;
  INT   iProtocol;
  DWORD dwMessageSize;
  LPSTR lpProtocol;
} PROTOCOL_INFOA, *PPROTOCOL_INFOA, *LPPROTOCOL_INFOA;

Membri

dwServiceFlags

Tipo: DWORD

Set di flag di bit che specifica i servizi forniti dal protocollo. È possibile impostare uno o più dei flag di bit seguenti.

Valore Significato
XP_CONNECTIONLESS
Se questo flag è impostato, il protocollo fornisce il servizio senza connessione (datagrammi). Se questo flag è chiaro, il protocollo fornisce il trasferimento dei dati orientato alla connessione.
XP_GUARANTEED_DELIVERY
Se questo flag è impostato, il protocollo garantisce che tutti i dati inviati raggiungano la destinazione prevista. Se questo flag è chiaro, non esiste una garanzia di questo tipo.
XP_GUARANTEED_ORDER
Se questo flag è impostato, il protocollo garantisce che i dati arrivino nell'ordine in cui è stato inviato. Si noti che questa caratteristica non garantisce la consegna dei dati, solo il relativo ordine. Se questo flag è chiaro, l'ordine dei dati inviati non è garantito.
XP_MESSAGE_ORIENTED
Se questo flag è impostato, il protocollo è orientato ai messaggi. Un protocollo orientato ai messaggi rispetta i limiti dei messaggi. Se questo flag è chiaro, il protocollo è orientato al flusso e il concetto di limiti dei messaggi è irrilevante.
XP_PSEUDO_STREAM
Se questo flag è impostato, il protocollo è un protocollo orientato ai messaggi che ignora i limiti dei messaggi per tutte le operazioni di ricezione.

Questa funzionalità facoltativa è utile quando non si vuole che il protocollo incornici i messaggi. Un'applicazione che richiede caratteristiche orientate al flusso può aprire un socket con SOCK_STREAM di tipo per i protocolli di trasporto che supportano questa funzionalità, indipendentemente dal valore di iSocketType.

XP_GRACEFUL_CLOSE
Se questo flag è impostato, il protocollo supporta operazioni di chiusura in due fasi, note anche come operazioni di chiusura normale. Se questo flag è chiaro, il protocollo supporta solo operazioni di chiusura interrotte.
XP_EXPEDITED_DATA
Se questo flag è impostato, il protocollo supporta i dati accelerati, noti anche come dati urgenti.
XP_CONNECT_DATA
Se questo flag è impostato, il protocollo supporta i dati di connessione.
XP_DISCONNECT_DATA
Se questo flag è impostato, il protocollo supporta i dati di disconnessione.
XP_SUPPORTS_BROADCAST
Se questo flag è impostato, il protocollo supporta un meccanismo di trasmissione.
XP_SUPPORTS_MULTICAST
Se questo flag è impostato, il protocollo supporta un meccanismo multicast.
XP_BANDWIDTH_ALLOCATION
Se questo flag è impostato, il protocollo supporta un meccanismo per l'allocazione di una larghezza di banda garantita a un'applicazione.
XP_FRAGMENTATION
Se questo flag è impostato, il protocollo supporta la frammentazione dei messaggi; MTU della rete fisica è nascosta dalle applicazioni.
XP_ENCRYPTS
Se questo flag è impostato, il protocollo supporta la crittografia dei dati.

iAddressFamily

Tipo: INT

Valore da passare come parametro af quando viene chiamata la funzione socket per aprire un socket per il protocollo. Questo valore della famiglia di indirizzi definisce in modo univoco la struttura degli indirizzi di protocollo, nota anche come sockaddr strutture, usate dal protocollo.

iMaxSockAddr

Tipo: INT

Lunghezza massima di un indirizzo socket supportato dal protocollo, in byte.

iMinSockAddr

Tipo: INT

Lunghezza minima di un indirizzo socket supportato dal protocollo, in byte.

iSocketType

Tipo: INT

Valore da passare come parametro tipo quando viene chiamata la funzione socket per aprire un socket per il protocollo.

Si noti che se XP_PSEUDO_STREAM è impostato in dwServiceFlags, l'applicazione può specificare SOCK_STREAM come parametro di tipo per socket, indipendentemente dal valore di iSocketType.

iProtocol

Tipo: INT

Valore da passare come parametro protocollo quando viene chiamata la funzione socket per aprire un socket per il protocollo.

dwMessageSize

Tipo: DWORD

Dimensioni massime dei messaggi supportate dal protocollo, in byte. Si tratta delle dimensioni massime di un messaggio che può essere inviato o ricevuto dall'host. Per i protocolli che non supportano il frame dei messaggi, le dimensioni massime effettive di un messaggio che possono essere inviate a un determinato indirizzo possono essere inferiori a questo valore.

Vengono definiti i valori di dimensioni speciali del messaggio seguenti.

Valore Significato
0
Il protocollo è orientato al flusso; il concetto di dimensione del messaggio non è rilevante.
0xFFFFFFFF
Il protocollo è orientato ai messaggi, ma non esiste alcuna dimensione massima del messaggio.

lpProtocol

Tipo: LPTSTR

Puntatore a una stringa con terminazione zero che fornisce un nome per il protocollo; ad esempio "SPX2".

Osservazioni

Nota

L'intestazione nspapi.h definisce PROTOCOL_INFO come alias che seleziona automaticamente la versione ANSI o Unicode di questa funzione in base alla definizione della costante del preprocessore UNICODE. La combinazione dell'utilizzo dell'alias indipendente dalla codifica con il codice non indipendente dalla codifica può causare mancate corrispondenze che generano errori di compilazione o di runtime. Per altre informazioni, vedere convenzioni di per i prototipi di funzioni.

Fabbisogno

Requisito Valore
client minimo supportato Windows 2000 Professional [solo app desktop]
server minimo supportato Windows 2000 Server [solo app desktop]
intestazione nspapi.h

Vedere anche

EnumProtocols

socket